C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt

上传人(卖家):罗嗣辉 文档编号:1817340 上传时间:2021-10-24 格式:PPT 页数:931 大小:19.45MB
下载 相关 举报
C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt_第1页
第1页 / 共931页
C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt_第2页
第2页 / 共931页
C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt_第3页
第3页 / 共931页
C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt_第4页
第4页 / 共931页
C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt_第5页
第5页 / 共931页
点击查看更多>>
资源描述

1、C+全册配套精品完整课件全册配套精品完整课件 谭浩强经典谭浩强经典C+(共共931页)页) 1 2 C+程序设计程序设计 3 第一章第一章C+概述概述 C+语言发展历史语言发展历史 自从自从1946年第一台电子数字计算机年第一台电子数字计算机ENIAC 问世以来,随着计算机应用领域的不断扩大,问世以来,随着计算机应用领域的不断扩大, 促进了计算机技术的高速发展,尤其是近年促进了计算机技术的高速发展,尤其是近年 来计算机的硬件和软件都是日新月异。作为来计算机的硬件和软件都是日新月异。作为 应用计算机的一种工具应用计算机的一种工具程序设计语言,得程序设计语言,得 到不断的充实和完善。每年都有新的程

2、序设到不断的充实和完善。每年都有新的程序设 计语言问世,老的程序设计语言不断地更新计语言问世,老的程序设计语言不断地更新 换代。换代。 4 20世纪世纪60年代,年代,Martin Richards为计算机软件人员为计算机软件人员 在开发系统软件时,作为记述语言使用而开发了在开发系统软件时,作为记述语言使用而开发了BCPL语语 言言(Basic Combined Programming Language)。1970年,年, Ken Thompson在继承在继承BCPL语言的许多优点的基础上发语言的许多优点的基础上发 明了实用的明了实用的B语言。到了语言。到了1972年,贝尔实验室的年,贝尔实验

3、室的Dennis Ritchie和和Brian kernighan在在B语言的基础上语言的基础上,作了进一步的作了进一步的 充实和完善,设计出了充实和完善,设计出了C语言。当时,语言。当时,设计设计C语言是为了语言是为了 编写编写UNIX操作系统的。操作系统的。以后以后,C语言经过多次改进语言经过多次改进,并开始并开始 流行。流行。C+是在是在C语言的基础上发展和完善的,语言的基础上发展和完善的,而而C是吸是吸 收了其它语言的优点逐步成为实用性很强的语言收了其它语言的优点逐步成为实用性很强的语言。 5 C语言的主要特点是:语言的主要特点是: 1、C语言是一种结构化的程序设计语言,语言是一种结构

4、化的程序设计语言,语言本语言本 身简洁、使用灵活方便身简洁、使用灵活方便。既适用于设计和编写大。既适用于设计和编写大 的系统程序,又适用于编写小的控制程序,也适的系统程序,又适用于编写小的控制程序,也适 用科学计算。用科学计算。 2、它既有高级语言的特点,又具有汇编语言的特它既有高级语言的特点,又具有汇编语言的特 点。点。运算符丰富,除了提供对数据的算术逻辑运算运算符丰富,除了提供对数据的算术逻辑运算 外,还提供了二进制的位运算。并且也提供了灵活外,还提供了二进制的位运算。并且也提供了灵活 的数据结构。用的数据结构。用C语言编写的程序表述灵活方便,语言编写的程序表述灵活方便, 功能强大。用功能

5、强大。用C语言开发的程序,其结构性好,目语言开发的程序,其结构性好,目 标程序质量高,程序执行效率高。标程序质量高,程序执行效率高。 6 3、程序的可移植性好程序的可移植性好。用。用C语言在某一种型号的计语言在某一种型号的计 算机上开发的程序,基本上可以不作修改,而直接算机上开发的程序,基本上可以不作修改,而直接 移植到其它型号和不同档次的计算机上运行。移植到其它型号和不同档次的计算机上运行。 4、程序的语法结构不够严密,程序设计的自由度程序的语法结构不够严密,程序设计的自由度 大大。这对于比较精通。这对于比较精通C语言的程序设计者来说,可语言的程序设计者来说,可 以设计出高质量的非常通用的程

6、序。但对于初学者以设计出高质量的非常通用的程序。但对于初学者 来说,要能比较熟练运用来说,要能比较熟练运用C语言来编写程序,并不语言来编写程序,并不 是一件容易的事情。与其它高级语言相比而言,调是一件容易的事情。与其它高级语言相比而言,调 试程序比较困难。往往是编好程序输入计算机后,试程序比较困难。往往是编好程序输入计算机后, 编译时容易通过,而在执行时还会出错。但只要对编译时容易通过,而在执行时还会出错。但只要对 C语言的语法规则真正领会,编写程序及调试程序语言的语法规则真正领会,编写程序及调试程序 还是比较容易掌握的。还是比较容易掌握的。 7 随着随着C语言应用的推广,语言应用的推广,C语

7、言存在的一语言存在的一 些缺陷或不足也开始流露出来,并受到大些缺陷或不足也开始流露出来,并受到大 家的关注。如:家的关注。如:C语言对数据类型检查的语言对数据类型检查的 机制比较弱;缺少支持代码重用的结构;机制比较弱;缺少支持代码重用的结构; 随着软件工程规模的扩大,难以适应开发随着软件工程规模的扩大,难以适应开发 特大型的程度等等。特大型的程度等等。 8 为了克服为了克服C语言本身存在的缺点,并保持语言本身存在的缺点,并保持C语言简语言简 洁、高效,与汇编语言接近的特点,洁、高效,与汇编语言接近的特点,1980年,贝年,贝 尔实验室的尔实验室的Bjarne Stroustrup博士及其同事对

8、博士及其同事对C语语 言进行了改进和扩充,并把言进行了改进和扩充,并把Simula 67中类的概念中类的概念 引入到引入到C中。并在中。并在1983年由年由Rick Maseitti提议正式提议正式 命名为命名为C+(C Plus Plus)。)。后来,后来,又把运算符的又把运算符的 重载、引用、虚函数等功能加入到重载、引用、虚函数等功能加入到C+中,使中,使C+ 的功能日趋完善。的功能日趋完善。 当前用得较为广泛的当前用得较为广泛的C+有:有:VC+ (Visual C Plus Plus)、)、 BC+(Borland C Plus Plus)、)、 AT /输出字符串输出字符串 主函数主

9、函数 函数体函数体 开始开始 函数体函数体 结束结束 输出流,在屏幕上打输出流,在屏幕上打 印引号内的字符串印引号内的字符串 分号,一条完整分号,一条完整 语句的结束符语句的结束符 本程序编译执行后,在本程序编译执行后,在DOS屏幕上打印出屏幕上打印出 I am a student. 包含文件包含文件 注释或说明注释或说明 11 编译过程:编译过程: 1)启动)启动Visual C+,选择选择“文件文件”菜单中的菜单中的“新建新建” 命令,选择命令,选择“文件文件”标签中的标签中的“C+ Source File” 选项。选项。 2)选择源程序存放的目录和输入源程序名,单击)选择源程序存放的目录

10、和输入源程序名,单击 “确定确定”。 3)在在编辑器中编写源程序。编辑器中编写源程序。 4)单击)单击F7或或“编译编译”中的中的“重建全部重建全部”编译源程编译源程 序,若编译通过,单击序,若编译通过,单击“执行执行”,在,在DOS屏上看屏上看 结果结果,任按一键返回编辑器。任按一键返回编辑器。 12 启动启动VC+ 编译系统编译系统 13 VC+编译编译 系统界面系统界面 单击单击“File”菜单菜单 中中“New”命令命令 14 选择选择“Files”选项卡选项卡 选择选择C+源源 文件命令文件命令 输入文件名输入文件名 输入文件输入文件 存放位置存放位置 单击选择单击选择 驱动器驱动器

11、 选择驱动选择驱动 器或目录器或目录 15 C+源文件源文件 编辑界面编辑界面 输入输入C+ 源代码源代码 16 可以将此源可以将此源 代码另起文代码另起文 件名存盘件名存盘 17 选择编译命令,将源文选择编译命令,将源文 件件.cpp生成生成.obj文件文件 18 如果编译出错,会出现提示信息,如果编译出错,会出现提示信息, 指出错误的位置及种类指出错误的位置及种类 错误所在行错误所在行 错误的原因错误的原因 19 双击错误双击错误 所在行所在行 光标移到该行光标移到该行 20 生成可执生成可执 行文件行文件 通过后单通过后单 击该命令击该命令 运行程序运行程序 21 运行结果显示运行结果显

12、示 在在DOS屏上屏上 注意:不可以在软盘上注意:不可以在软盘上 运行程序!应该把保存运行程序!应该把保存 在软盘中的源文件拷贝在软盘中的源文件拷贝 到硬盘的目录中再运行到硬盘的目录中再运行! 22 源程序所在目录源程序所在目录 未编译前,只未编译前,只 有一个源程序有一个源程序 23 编译运行后,出编译运行后,出 现众多附加文件现众多附加文件 同时,产生一个同时,产生一个 子目录子目录Debug 24 Debug目录中,有目录中,有 obj和和EXE文件文件 25 #include void main(void) cout i; /从键盘上输入变量从键盘上输入变量i的值的值 cout “i的

13、值为:的值为:” in; / 输出变量输出变量i的的 值值 另一个例子另一个例子 26 第二章第二章 数据类型、运算符与表达式数据类型、运算符与表达式 27 2000H 2001H 2002H 2003H 2004H 3 3+5=? 5 运算器运算器 (2000H)+(2002H) 用一个字节表示整数,范围为用一个字节表示整数,范围为-128127;用两个字节表;用两个字节表 示整数,范围为示整数,范围为-32768 32767。一般用四个字节表示整。一般用四个字节表示整 数。数。(举例举例) 内存内存 CPU内存内存 data 外存外存 Program 8 硬盘硬盘 软盘软盘 28 1514

14、 13 12 11 109876543210 有符号数有符号数无符号数无符号数 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 13276732767 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 03276632766 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 111 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 000 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1-1(补码补码)65535 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0-265534 1 0 0 0 0 0 0 0 0 0 0 0

15、0 0 0 1-3276732769 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0-3276832768 29 常量与变量常量与变量 常量:在程序运行过程中,其值一直保持不变的常量:在程序运行过程中,其值一直保持不变的 量为常量。量为常量。 常量也区分不同的类型:常量也区分不同的类型:30,40 为整型,为整型,30.0, 40.0为实型,为实型,编辑器只是根据其表面形式来判断其编辑器只是根据其表面形式来判断其 类型。类型。 变量:在程序运行过程中,其值可以改变的量为变量:在程序运行过程中,其值可以改变的量为 变量。变量。 变量在程序的执行中能够赋值,发生变化变量在程序的执行

16、中能够赋值,发生变化。变量。变量 有一个名字,有一个名字,并在使用之前要说明其类型并在使用之前要说明其类型,一经,一经 说明,说明,就在内存中占据与其类型相应的存储单元。就在内存中占据与其类型相应的存储单元。 30 #include #define PRICE 30 /常量,在程序中保持不变常量,在程序中保持不变 void main(void) int num, total; /定义变量定义变量,在内存中开辟区间在内存中开辟区间 num=10; /变量赋值变量赋值,10为常量为常量 total=num*PRICE; cout“total=“total; /输出结果输出结果 其中:其中:num=

17、10 total=num*PRICE 是赋值号,不同于数学意义上的等号。是赋值号,不同于数学意义上的等号。 numtotal 10 300 PRICE 30 31 C+中有多种数据类型,均有常量与变量之分,各中有多种数据类型,均有常量与变量之分,各 占不同的内存空间,正确定义与使用数据是编写占不同的内存空间,正确定义与使用数据是编写 程序的基本前提。程序的基本前提。 32 变量名的命名方法:变量名的命名方法: 变量名、数组名、函数名变量名、数组名、函数名称为称为标识符标识符。 标识符只能由标识符只能由字母、数字、下划线字母、数字、下划线这三种字符组成,且第这三种字符组成,且第 一个字符必须为字

18、母或下划线,长度不大于一个字符必须为字母或下划线,长度不大于247个字符,个字符, 大小写不通用大小写不通用。(关键字不能作为标识符)。(关键字不能作为标识符)。 关键字即是关键字即是VC+的语法要求中使用的字的语法要求中使用的字。 如如 int if while 等。等。 正确的标识符:正确的标识符:INT, sum , de12, SUM等。等。变量必须使变量必须使 用前定义,以分配空间。用前定义,以分配空间。 举例说明举例说明 33 abc English 2xy x-y if Else b(3) def Chine_bb b3y AbsFloat float 一般变量都是用匈牙利命名法

19、命名的。一般变量都是用匈牙利命名法命名的。 int nCount; char chChoice; 34 整型数据整型数据 整型常量:整型常量: 常量是根据其表面形式来判定,整型量即是没有小数点的常量是根据其表面形式来判定,整型量即是没有小数点的 整数,范围:整数,范围:-231(231-1) ,有三种形式,有三种形式: 1)十进制(默认方式)十进制(默认方式)43 1345 87654 2)八进制)八进制 以以0开头开头 043, 056, 011 3)十六进制)十六进制 以以0 x开头开头 0 x12 0 xa3 0 x34 0 xdf (举例说明)(举例说明) 35 #include vo

20、id main(void) int int10,int8,int16; /定义定义3个整型变量个整型变量 int10=10;/默认为十进制默认为十进制 int8=010;/八进制八进制 int16=0 x10;/十六进制十六进制 coutint10=int10endl; coutint8=int8endl; coutint16=int16endl; 输出输出 int10=10 int8=8 int16=16 36 整型变量:整型变量: 分为有符号型与无符号型。分为有符号型与无符号型。 有符号型:有符号型: short 在内存中占两个字节,范围为在内存中占两个字节,范围为-215(215-1)

21、int 在内存中占四个字节,范围为在内存中占四个字节,范围为-231(231-1) long在内存中占四个字节,范围为在内存中占四个字节,范围为-2-31231-1 无符号型:无符号型:最高位不表示符号位最高位不表示符号位 unsigned short 在内存中占两个字节,范围为在内存中占两个字节,范围为0216-1 unsigned int 在内存中占四个字节,范围为在内存中占四个字节,范围为0232-1 unsigned long在内存中占四个字节,范围为在内存中占四个字节,范围为0232-1 37 1)整型常量整型常量亦有长短之分,常量中无亦有长短之分,常量中无unsigned型,但一型

22、,但一 个非负的整型常量可以赋给个非负的整型常量可以赋给unsigned型的变量。型的变量。 2)若一个常量定义为长整型数,则在其后加)若一个常量定义为长整型数,则在其后加l或或L进行区进行区 分。分。 如:如:32l 32L 564L等,内存为其分配四个字节存储。等,内存为其分配四个字节存储。 一个数在内存中为一个数在内存中为 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 当这个数为有符号数时,是当这个数为有符号数时,是-1;为无符号数时,是;为无符号数时,是232-1 内存中的数是以内存中的数是以补码补码的形式存放的。(举例说明)的形式存放的。(举例说明) 1 1 1 1

23、 1 1 1 1 1 1 1 1 1 1 1 1 38 #include void main() unsigned short a; short int b= -1; a=b; couta=aendl; 结果:结果:65535 不同类型的整型数据间不同类型的整型数据间 的赋值归根到底就是一的赋值归根到底就是一 条:条:按存储单元中的存按存储单元中的存 储形式直接传送。储形式直接传送。 a 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 b 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 unsigned short a; 39 实型数据实型数据 实型数又称浮点数

24、,有两种表示方式:实型数又称浮点数,有两种表示方式: 1)十进制形式:)十进制形式: 23.0 24.5 3.56789 2) 指数形式:指数形式: 23E1 145e-1 356789e1 e前有数字,后前有数字,后 面必须是整数。面必须是整数。 实型变量分单精度实型变量分单精度 float 和双精度和双精度 double 两种形式:两种形式: float:占四个字节,提供占四个字节,提供78位有效数字。位有效数字。 double: 占八个字节,提供占八个字节,提供1516位有效数字。位有效数字。 举例说明举例说明 40 #include void main(void) float a, b

25、; double c, d; a=0.01; b=3.45678e-2; c=3.45678e-2; d=9.7654e-5; couta=atb=bendl; coutc=ctd=dendl; a=0.01 b=0.0345678 c=0.0345678 d=9.7654e-005 Press any key to continue 41 如果为实数,则用浮点数的形式在内存存储,表示如下:如果为实数,则用浮点数的形式在内存存储,表示如下: JtJSfS 阶符阶符阶码阶码数符数符尾数尾数 实数是既有整数又有小数的数。实数是既有整数又有小数的数。 实数可以表示成:实数可以表示成:N=SRJ S

26、称为尾数,尾数决定有效数字,即数字的精度。称为尾数,尾数决定有效数字,即数字的精度。 J 表示指数(阶码)。表示指数(阶码)。 R 是基数,可取是基数,可取2,4,8,16等,对具体机器而言,基数等,对具体机器而言,基数 取好后,就不能再变了。取好后,就不能再变了。 数有正有负数有正有负, 所以设置数符所以设置数符; 阶码亦有正负阶码亦有正负, 所以设置阶符所以设置阶符 42 一般用一般用4个字节表示一个浮点数,也有用个字节表示一个浮点数,也有用8个字个字 节表示的。节表示的。 字长一定,尾数越多,精度越高;阶码越多,字长一定,尾数越多,精度越高;阶码越多, 范围越大。范围越大。 当计算机中出

27、现小于机器所能表示的最小数当计算机中出现小于机器所能表示的最小数 时,机器只能当零来处理时,机器只能当零来处理,当出现超过机器所能当出现超过机器所能 表示的最大数时,出现溢出现象表示的最大数时,出现溢出现象,一旦出现溢出,一旦出现溢出, 就会停止运算。就会停止运算。定点数,浮点数均会出现溢出现定点数,浮点数均会出现溢出现 象。象。 43 字符型数据(字符型数据(char) 字符型数据实际上是作为字符型数据实际上是作为整型数据整型数据在内存中存储的。在内存中存储的。 计算机是以字符编码的形式处理字符的,因此,我们在计算机内部计算机是以字符编码的形式处理字符的,因此,我们在计算机内部 是以是以AS

28、CII码码的形式表示所有字符的。所以的形式表示所有字符的。所以7位二进制数即可表示出位二进制数即可表示出 一个字符,一个字符,我们用一个字节的容量(我们用一个字节的容量(8位)存储一个字符。位)存储一个字符。 例如:字符例如:字符A的的ASCII码为码为0 x41或或65,在内存中表示为:,在内存中表示为: 01000001 在程序中表示为:在程序中表示为: char grade ;/定义一个字符型的变量空间定义一个字符型的变量空间(1个字节个字节) grade=A; /必须用必须用 表示,否则易与标识符混同表示,否则易与标识符混同 内括起来的字符表示该字符的内括起来的字符表示该字符的ASCI

29、I码。码。 44 进一步,由于在内存中的形式与整型数据相同,所以,进一步,由于在内存中的形式与整型数据相同,所以,可以直接用可以直接用 其整型值给变量赋值。其整型值给变量赋值。 char grade; grade=65; 以下的赋值形式均是等同的。以下的赋值形式均是等同的。 grade=A; grade=65 ; grade=0 x41; grade=0101; #include void main(void) char a,b; a=A; /输入输入ASCII码码 b=65; /输入十进制数输入十进制数 couta=aendl; coutb=bendl; 输出:输出: a=A b=A 即在内

30、存中的表示均是相同的即在内存中的表示均是相同的 01000001 45 非打印字符非打印字符 有些有些ASCII的字符代表某些操作,不能打印出来,的字符代表某些操作,不能打印出来, 如回车、退格等,可用两种方式表示这些字符。如回车、退格等,可用两种方式表示这些字符。 1)用)用ASCII码的形式码的形式 char re=13; 2)用转义字符)用转义字符 char re=n;(p15) 46 转义字符转义字符含含 义义 ASCII代码代码 a响铃响铃7 换行,将当前位置移到下一行开头换行,将当前位置移到下一行开头10 水平制表(跳到下一个水平制表(跳到下一个tab位置)位置)9 退格,将当前位

31、置移到前一列退格,将当前位置移到前一列8 回车,将当前位置移到本行开头回车,将当前位置移到本行开头13 换页,将当前位置移到下页开头换页,将当前位置移到下页开头12 v竖向跳格竖向跳格8 反斜杠字符反斜杠字符“”92 单引号(撇号)字符单引号(撇号)字符39 双引号字符双引号字符34 0空字符空字符0 ddd1到到3位位8进制数所代表的字符进制数所代表的字符 xhh1到到2位位16进制数所代表的字符进制数所代表的字符 47 转义字符虽然包含转义字符虽然包含2个或多个字符,但它只代个或多个字符,但它只代 表一个字符。表一个字符。编译系统在见到字符编译系统在见到字符“”时,时, 会接着找它后面的字

32、符,把它处理成一个字会接着找它后面的字符,把它处理成一个字 符,在内存中只占一个字节。符,在内存中只占一个字节。 48 典型转义字符典型转义字符 : n换行换行 b 退格退格 t 下一个输出下一个输出 区区 若输出中包含这些特定格式,则再加一个若输出中包含这些特定格式,则再加一个 输出输出 c:tctc 表示为表示为coutc:tctc; 可以用转义字符表示任一一个可以用转义字符表示任一一个ASCII字符字符 ddd (八进制)八进制) xhh (十六进制)(十六进制) 101 x41 x61 141 49 #include void main(void) char c1,c2,c3,c4;

33、char n1,n2; c1=a;/字符常量字符常量 c2=97;/十进制十进制 c3=x61;/转义字符转义字符 c4=0141;/八进制八进制 coutc1=c1tc2=c2endl; coutc3=c3tc4=c4endl; n1=n; /转义字符:回车转义字符:回车 n2=t; /转义字符:下一个输出区转义字符:下一个输出区(Tab) cout使用转义字符使用转义字符n; coutc1=c1n2c2=c2n1; coutc3=c3n2c4=c4n1; 输出:输出: c1=a c2=a c3=a c4=a 使用转义字符使用转义字符 c1=a c2=a c3=a c4=a 50 字符串常量

34、:字符串常量: 用用 表示,表示,在内存中顺序存放,以在内存中顺序存放,以0结束。结束。 如:如:CHINA 0 x430 x480 x490 x550 x410 a在内存中占一个字节在内存中占一个字节 a占两个字节占两个字节aa0 实际上实际上内存是对应字符的内存是对应字符的ASCII码形式码形式 010000110100100001001001010101010100000100000000 CHINA0 011000010110000100000000 51 标识符常量标识符常量 在在C+中有二种方法定义中有二种方法定义标识符常量标识符常量,一种是使用编译预,一种是使用编译预 处理指令;

35、另一种是使用处理指令;另一种是使用C+的常量说明符的常量说明符const。 例如:例如: #define PRICE 30 /在程序中凡是出现在程序中凡是出现PRICE均用均用30替代替代 #define PI 3.1415926 #define S “China” const float pi=3.1415926; /将将变量变量pi定义为定义为常量常量 (举例说明)(举例说明) 52 #include #define PI 3.14156 #define S China void main(void) const float pi=3.14156;/变量作为常量使用变量作为常量使用 cou

36、tPI=PIendl; cout10*PI=10*PIendl; coutSendl; / PI=PI+3; / pi=pi+4; coutPI=PIendl; coutpi=piendl; 输出:输出: PI=3.14156 10*PI=31.4156 China PI=3.14156 pi=3.14156 53 下列常量的表示在下列常量的表示在C+C+中是否合法?若不合法,指出原因;中是否合法?若不合法,指出原因; 若合法,则指出常量的数据类型。若合法,则指出常量的数据类型。 32767 35u 1.25e3.43L 0.0086e-32 87 “Computer System” “a”

37、a 9645 -0+0.5-.567 54 变量变量 1) 在程序的执行过程中,其值可以改变的量在程序的执行过程中,其值可以改变的量 称为变量。称为变量。 2) 变量名必须用标识符来标识。变量名必须用标识符来标识。 3) 变量根据其取值的不同值域,分为不同类变量根据其取值的不同值域,分为不同类 型的变量:整型变量、实型变量、字符型变型的变量:整型变量、实型变量、字符型变 量、构造型变量、指针型变量等等。量、构造型变量、指针型变量等等。 55 4) 对于任一变量,对于任一变量,编译程序要为其分配若干编译程序要为其分配若干 个字节(连续的)的内存单元,以便保存变个字节(连续的)的内存单元,以便保存

38、变 量的取值量的取值。 5) 当要改变一个变量的值时,就是把变量的当要改变一个变量的值时,就是把变量的 新的取值存放到为该变量所分配的内存单元新的取值存放到为该变量所分配的内存单元 中;用到一个变量的值时,就是从该内存单中;用到一个变量的值时,就是从该内存单 元中取出数据。元中取出数据。 6) 不管什么类型的变量,通常均是不管什么类型的变量,通常均是变量的说变量的说 明在前,使用变量在后。明在前,使用变量在后。 56 int i, j, k;/定义了三个整型变量定义了三个整型变量i,j,k float x,y,z;/定义了三个实型变量定义了三个实型变量x,y,z char c1,c2; /说明

39、了二个字符型变量说明了二个字符型变量c1,c2 double dv1;/说明了一个双精度型变量说明了一个双精度型变量dv1 k 四个字节的四个字节的 连续空间连续空间 j 四个字节的四个字节的 连续空间连续空间 i 四个字节的四个字节的 连续空间连续空间 z 四个字节的四个字节的 连续空间连续空间 y 四个字节的四个字节的 连续空间连续空间 x 四个字节的四个字节的 连续空间连续空间 dv1 八个字节的八个字节的 连续空间连续空间 c2 1个字节的个字节的 空间空间 c1 1个字节的个字节的 空间空间 开辟空间后开辟空间后, 空空 间中为随机值间中为随机值 57 变量赋初值变量赋初值 在定义变

40、量的在定义变量的同时同时给变量赋值,即在内存中开辟出一个空给变量赋值,即在内存中开辟出一个空 间后马上给此空间赋值。间后马上给此空间赋值。 但这个空间的值并不是固定不变的,但这个空间的值并不是固定不变的,在程序的运行中一样在程序的运行中一样 可以改变。可以改变。 char a=x64, b=d; int a1=6, a2=98; a=A; b=n; a1=011; a2=121; int a=4; /定义语句,在开辟空间后马上为空间赋值定义语句,在开辟空间后马上为空间赋值 a=6; /重新为该空间赋值重新为该空间赋值 a 4 6 58 算术运算符和算术表达式算术运算符和算术表达式 一、算术运算

41、符和算术表达式一、算术运算符和算术表达式 + * % 用算术运算符连接起来的式子是算术表达式用算术运算符连接起来的式子是算术表达式 两个整数相除结果为整数两个整数相除结果为整数 1/2=0 5/2=2 整数才可求余,余数的符号与左边数的符号相同。整数才可求余,余数的符号与左边数的符号相同。 3%2=1 -3%2=-1 3%-2=1 -3%-2=-1 8%4=0 二、优先级与结合性二、优先级与结合性 ()() * / % + 59 三、强制转换类型三、强制转换类型 (类型名)(表达式)(类型名)(表达式) (double) a (int) (x+y) (int) 6.2%4=2 在强制类型运算后

42、原变量不变,但得到一个所需在强制类型运算后原变量不变,但得到一个所需 类型的中间变量。类型的中间变量。 如:如:int x; float y=5.8; x=(int)y; x=5 y=5.8 y的值没有改的值没有改 变,仍是单精变,仍是单精 度浮点型度浮点型 60 四、自增、自减运算符四、自增、自减运算符 (难点)难点) + i 6 i 3 7 int i, j; i=3; j = +i; i=4 j=4 +在前在前, 先运算先运算,后赋值后赋值 int i, j; i=3; j = i+; i=4 j=3 +在后在后, 先赋值先赋值,后运算后运算 j 44 i 3 j 34 i=6; i+;

43、 i=i+1 i=7 +i; i=i+1 i=7 i=6; i; i=i1 i=5 i ; i=i1 i=5 i 6 7 61 1)自增、自减运算符只能用于变量,不可用于常量和表自增、自减运算符只能用于变量,不可用于常量和表 达式达式 因为表达式在内存内没有具体空间,常量所占的空间不能因为表达式在内存内没有具体空间,常量所占的空间不能 重新赋值重新赋值 3+ (x+y)+ (i)+ 若若i=3, j=2 (i+) +j 等于等于5i=4, j=2 2)结合方式自右至左,优先级最高,向右取最大)结合方式自右至左,优先级最高,向右取最大 i+ (i+) i+j (i+) +j 62 赋值运算符和赋

44、值表达式赋值运算符和赋值表达式 bmw=2002 =左边左边必须是变量名。必须是变量名。 若若“ = ” 两边变量类型不同,在赋值时要进两边变量类型不同,在赋值时要进 行行类型转换类型转换。 转换原则:根据左边变量的类型转换。转换原则:根据左边变量的类型转换。 63 少字节少字节多字节多字节 1)若多字节变量为)若多字节变量为unsigned ,则转换后多余字节补则转换后多余字节补 零。零。 0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 unsigned short int a=-1; unsigned long b; b=a; a a b b

45、 64 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 有符号型,符号扩展有符号型,符号扩展 short int a=-1; long b; b=a; 2)若多字节变量为有符号型,则转换后扩展少字)若多字节变量为有符号型,则转换后扩展少字 节的最高位。节的最高位。 转换后,数据的符号不变。转换后,数据的符号不变。 a a b b 65 多字节多字节少字节少字节 低位照搬低位照搬 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 int a=-1; short int b; b=a; b=-1 int a=65535; short i

46、nt b; b=a;b=-1 b b a a 1 1 1 1 1 1 1 1 66 赋值表达式赋值表达式 a=b=5 ; b=5 a=5 =的结合性为的结合性为自右至左自右至左 复合的赋值运算符复合的赋值运算符 a+=3 a=a+3 x*=y+3 x=x*(y+3) x/=x-4 x=x/(x-4) x+=y x=x+y i+=j- i=i+(j-) 67 a=12; a+=a-=a*a; 12a a=a-(a * a) =12-(12*12)=-132 a=a+(-132)=-132-132=-264 -132-264 68 关系运算符和关系表达式关系运算符和关系表达式 关系运算符(比较运算

47、)关系运算符(比较运算) = = = != 1. = = 与与 = a=5; 赋值运算赋值运算 a= =5;判断是否相等判断是否相等 2. = 的优先级大于的优先级大于= = != 3. 算术运算符的优先级大于关系运算符的优先级算术运算符的优先级大于关系运算符的优先级 69 关系表达式:用关系运算符将表达式连接起来称关系表达式:用关系运算符将表达式连接起来称 为关系表达式。其值非真即假。在为关系表达式。其值非真即假。在C+语言中,用语言中,用 非非0代表真,用代表真,用0表示假。表示假。关系表达式的结果只有关系表达式的结果只有 两个,真为两个,真为1,假为,假为0。 a=2 b=3 c=4 a

48、2 ab+c a= =2 a= =a aa b=a= =2 aA b= =a+1 c-a= =a 0 0 1 0 0 1 1 0 1 70 逻辑运算符逻辑运算符 1. 运算符运算符 与与 a=3 a=3*3, a+6, a+7; 16 (a=3*5, a*4), a+520 a=9 a=15 77 下列语句中表达式中下列语句中表达式中i, j的值各为多少的值各为多少 1、int i=0, j=0; 2、 int i=0, j=1; i=3, (j+)+i ; i+=j*=3; 3、int i=1, j=0; 4、int i=1, j=1; j=i=(i=3)*2); i+=j+=2; i=3,

49、j=1 i=3,j=3 i=6,j=6i=4,j=3 78 各类数值型数据间的混合运算各类数值型数据间的混合运算 整型、实型、字符型数据间可以混合运算。整型、实型、字符型数据间可以混合运算。 floatdouble long unsigned int char 10+a+1.5-87.65*b 在进行运算时,在进行运算时,不同类型的数据要先转换成同一不同类型的数据要先转换成同一 类型的数据再进行运算。类型的数据再进行运算。 转换规则如下:转换规则如下: 79 第三章第三章 简单的输入输出简单的输入输出 80 输入语句:输入语句:cin 程序在执行期间,程序在执行期间,接收外部信息的操作称为接收

50、外部信息的操作称为 程序的输入程序的输入;而把;而把程序向外部发送信息的操程序向外部发送信息的操 作称为程序的输出作称为程序的输出。在。在C+中没有专门的输中没有专门的输 入输出语句,所有输入输出是通过入输出语句,所有输入输出是通过输入输出输入输出 流流来实现的。来实现的。 81 要使用要使用C+提供的输入输出时,必须在程序提供的输入输出时,必须在程序 的开头增加一行:的开头增加一行: #include 即包含输入输出流的头文件即包含输入输出流的头文件“iostream.h”。 有关包含文件的作用,在编译预处理部分有关包含文件的作用,在编译预处理部分 (第五章)作详细介绍。(第五章)作详细介绍

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 大学
版权提示 | 免责声明

1,本文(C++全册配套精品完整课件6谭浩强经典C++(共931页).ppt)为本站会员(罗嗣辉)主动上传,163文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。
2,用户下载本文档,所消耗的文币(积分)将全额增加到上传者的账号。
3, 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(发送邮件至3464097650@qq.com或直接QQ联系客服),我们立即给予删除!


侵权处理QQ:3464097650--上传资料QQ:3464097650

【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。


163文库-Www.163Wenku.Com |网站地图|