东南大学C++总课件.ppt

上传人(卖家):晟晟文业 文档编号:5190449 上传时间:2023-02-16 格式:PPT 页数:1095 大小:4MB
下载 相关 举报
东南大学C++总课件.ppt_第1页
第1页 / 共1095页
东南大学C++总课件.ppt_第2页
第2页 / 共1095页
东南大学C++总课件.ppt_第3页
第3页 / 共1095页
东南大学C++总课件.ppt_第4页
第4页 / 共1095页
东南大学C++总课件.ppt_第5页
第5页 / 共1095页
点击查看更多>>
资源描述

1、东南大学C+总程序设计与语言()培养目标课程简介实验学时考核形式教材主讲:何洁月东南大学C+总培养目标 1.建立基本的计算机程序设计概念体系和基本的程序设计方法。2.理解和掌握C+语言的基本语法和语义,初步理解面向对象的思想,初步掌握面向对象程序设计的方法。3.逐步提高学生的编程能力和调试程序的能力。为后面的学习打好基础。东南大学C+总课程简介 第章 概述 计算机程序设计语言的发展(一般了解)面向对象的方法(一般了解)面向对象的软件开发(一般了解)信息的表示与存储(理解)程序的开发过程(一般了解)小结东南大学C+总课程简介 第章 简单程序设计 语言概述(一般理解)基本数据类型和表达式(掌握)数

2、据的输入与输出(掌握)算法的基本控制结构(掌握)自定义数据类型(掌握)小结东南大学C+总课程简介 第章 函数 函数的定义与使用(掌握)内联函数(掌握)带默认形参值的函数(掌握)函数重载(掌握)函数模板(掌握)使用系统函数(掌握)小结东南大学C+总课程简介 第章 类与对象 面向对象的思想(理解)面向对象程序设计的基本特点(理解)类和对象(掌握)构造函数和析构函数(掌握)类的组合(掌握)类模板(掌握)面向对象标记(一般了解)小结东南大学C+总课程简介 第章 程序的结构 程序的结构(理解)生存期(掌握)数据和函数(掌握)静态成员(掌握)友元(掌握)共享数据的保护(掌握)多文件结构和编译预处理命令(掌

3、握)小结东南大学C+总课程简介 第章 数组、指针与字符串 数组(掌握)指针(掌握)动态内存分配(掌握)字符串(掌握)东南大学C+总实验 实验共分次,每次小时,实验环境为:visual c+6.0 实验:visual c+6.0开发环境应用入门 实验:简单程序设计 实验:函数的应用 实验:类与对象 实验:程序的结构 实验:数组、指针与字符串东南大学C+总教材 教材:C+语言程序设计 C+语言程序设计习题与实验指导东南大学C+总考核 总评成绩=平时作业+上机实验+期末笔试成绩(闭卷)期末上机成绩(闭卷)平时作业占 10%平时上机实验占 10%期末笔试成绩(闭卷)占 60%期末上机成绩(闭卷)占 2

4、0%东南大学C+总第一章 绪论 计算机程序设计语言的发展 面向对象的方法 面向对象的软件开发 信息的表示与存储 程序的开发过程东南大学C+总1.1计算机语言的发展 计算机的工作是用程序来控制的 程序是指令的集合。指令是计算机可以识别的命令。计算机程序计算机程序东南大学C+总机器语言 由计算机硬件系统可以识别的二进制指令组成的语言称为机器语言。计算机发展的初期,软件工程师们只能用机器语言来编写程序。这一阶段,在人类的自然语言和计算机编程语言之间存在着巨大的鸿沟。例如 1011 1111 1101 缺点:难懂,不易修改,移植性差东南大学C+总汇编语言 汇编语言将机器指令映射为一些可以被人读懂的助记

5、符,如ADD、SUB等。此时编程语言与人类自然语言间的鸿沟略有缩小,但仍与人类的思维相差甚远。因为它的抽象层次太低,程序员需要考虑大量的机器细节。例如 ADD CX,DX 将DX的内容加进CX。不能立即执行,需要汇编,变成目标程序。东南大学C+总高级语言高级语言屏蔽了机器的细节,提高了语言的抽象层次,程序中可以采用具有一定涵义的数据命名和容易理解的执行语句。这使得在书写程序时可以联系到程序所描述的具体事物。例如 if y实数的加法 -复数的加法 例动物叫东南大学C+总面向对象的软件工程 面向对象的软件工程是面向对象方法在软件工程领域的全面应用。它包括:面向对象的分析(OOA)面向对象的设计(O

6、OD)面向对象的编程(OOP)面向对象的测试(OOT)面向对象的软件维护(OOSM)面向对象的软件开发东南大学C+总问题域问题域需求分析需求分析总体设计总体设计详细设计详细设计编程编程测试测试计算机计算机自然语言自然语言编程语言编程语言分析与设计分析与设计的鸿沟的鸿沟问题域问题域OOAOOAOODOODOOPOOPOOTOOT自然语言自然语言面向对象的编面向对象的编程语言程语言计算机计算机传统的软件工程方法传统的软件工程方法面向对象的软件工程方法面向对象的软件工程方法自然语言自然语言分析与设计分析与设计的鸿沟的鸿沟编程语言编程语言自然语言自然语言面向面向对象对象的编的编程语程语言言东南大学C+

7、总系统分析 系统分析阶段应该扼要精确地抽象出系统必须做什么,但是不关心如何去实现。面向对象的系统分析,直接用问题域中客观存在的事物建立模型中的对象,对单个事物及事物之间的关系,都保留他们的原貌,不做转换,也不打破原有界限而重新组合,因此能够很好地映射客观事物。东南大学C+总设计 针对系统的一个具体实现运用面向对象的方法。其中包括两方面的工作:把OOA模型直接搬到OOD,作为OOD的一部分 针对具体实现中的人机界面、数据存储、任务管理等因素补充一些与实现有关的部分。东南大学C+总编程OOP工作就是用一种面向对象的编程语言把OOD模型中的每个成分书写出来,是面向对象的软件开发最终落实的重要阶段。东

8、南大学C+总测试 测试的任务是发现软件中的错误。在面向对象的软件测试中继续运用面向对象的概念与原则来组织测试,以对象的类作为基本测试单位,可以更准确的发现程序错误并提高测试效率。东南大学C+总维护将软件交付使用后,工作并没有完结,还要根据软件的运行情况和用户的需求,不断改进系统。使用面向对象的方法开发的软件,其程序与问题域是一致的,因此,在维护阶段运用面向对象的方法可以大大提高软件维护的效率。东南大学C+总信息的表示和存储 信息的分类 计算机的数字系统 程序设计中常用的数制 不同进位计数制间的转换 信息的存储单位 二进制数的编码表示 小数的表示方法 非数值信息的表示东南大学C+总信息的分类 指

9、令 控制信息 控制字 信息 定点数 数值信息 数据信息 浮点数 字符数据 非数值信息 逻辑数据东南大学C+总计算机的数字系统 计算机采用的是二进制数字系统。基本符号:0、1 进位原则:逢二进一 优点:易于物理实现 二进制数运算简单 机器可靠性高 通用性强 缺点:对人来说可读性差东南大学C+总程序设计中常用的数制进制 基 数 进位原则 基本符号 二进制 2 逢 2 进 1 0,1 八进制 8 逢 8 进 1 0,1,2,3,4,5,6,7 十进制 10 逢 10 进 1 0,1,2,3,4,5,6,7,8,9,十六进制 16 逢 16 进 1 0,1,2,3,4,5,6,7,8,9,A,B,C,

10、D,E,F 东南大学C+总不同进位计数制间的转换 R 进制十进制各位数字与它的权相乘,其积相加。例如:(11111111.11)2=1*27+1*26+1*25+1*24+1*23+1*22+1*21+1*20+1*2-1+1*2-2=(255.75)10(3506.2)8=3*83+5*82+0*81+6*80+2*8-1=(1862.25)10(0.2A)16=2*16-1+10*16-2=(0.1640625)10东南大学C+总不同进位计数制间的转换 十进制 R 进制十进制整数转换成R进制的整数“除R取余”法,例如:2 68 余 数 2 34 0 低位 2 17 0 2 8 1 2 4

11、0 2 2 0 2 1 0 0 1 高位所以 681010001002东南大学C+总不同进位计数制间的转换 十进制 R 进制十进制小数转换成R进制小数“乘 R 取整”法,例如:高位 0.31252=0.625 0.625 2=1.25 0.25 2=0.5 0.5 2=1.0所以 0.312510 =0.01012 东南大学C+总不同进位计数制间的转换二、八、十六进制的相互转换 每位八进制数相当于三位二进制数 每位十六进制数相当于四位二进制数(1 0 1 1 0 1 0.1 0)2=(0 0 1 0 1 1 0 1 0 .1 0 0)2=(132.4)8(1 0 1 1 0 1 0.1 0)2

12、=(0 1 0 1 1 0 1 0 .1 0 0 0)2=(5A.8)16(F7)16(1111 0111)2(11110111)2东南大学C+总信息的存储单位 位(bit):度量数据的最小单位,表示一位二进制信息。字节(byte):由八位二进制数字组成(1 byte=8 bit)。K 字节 1 K=1024 byteM 字节 1 M=1024 KG 字节 1 G=1024 M 东南大学C+总二进制数的编码表示:原码 符号绝对值表示的编码例如:X=+0101011 X原=0 0101011X=-0101011 X原=1 0101011 符号位 缺点:零的表示不唯一:+0原=000.0 -0原=

13、100.0 进行四则运算时,符号位需单独处理,且运算规则复杂。东南大学C+总二进制数的编码表示:反码 正数的反码与原码表示相同。负数的反码与原码有如下关系:符号位相同(仍用1表示),其余各位取反(0变1,1变0)。例如:X=-1100110 X原=11100110 X反=10011001X=+0000000 X原=00000000 X反=00000000 反码中零的表示也不唯一X=-0000000 X原=10000000 X反=11111111 反码只是求补码的中间码东南大学C+总二进制数的编码表示:补码 模数:n位整数(包括一位符号位),则它的模数为 2n。n位小数,小数点前一位为符号位,则

14、它的模数为 2。补数:一个数减去另一个数,或者说一个数加上一个负数,等于第一个数加上第二个数的补数。例:8+(-2)=8+10(mod 12)一个二进制负数可用其模数与真值做加法(模减去该数的绝对值)求得其补码。东南大学C+总二进制数的编码表示:补码 计算机中的补码表示法 负数的补码由该数反码的末位加 1 求得 对补码再求补即得到原码 补码运算规则p14 符号位可作为数值参加运算 减法运算可转换为加法运算:加上一个负数等于加上该数的补码 补码运算的结果仍为补码 运算结果溢出:负数之和得正数,或正数之和得负数东南大学C+总小数的表示方法 计算机中通常采用浮点方式表示小数一个数 N 用浮点形式表示

15、可以写成:N=M2E E表示2的幂,称为数N的阶码。阶码确定了数N的小数点的位置,其位数反映了该浮点数所表示的数的范围。M表示数N的全部有效数字,称为数N的尾数。其位数反映了数据的精度。p15东南大学C+总非数值信息的表示 西文字符:ASCII码:用7位二进制数表示一个字符,最多可以表示27=128个字符 EBCDIC码:用8位二进制数表示一个字符,最多可以表示28=256个字符 汉字:应用较为广泛的是国家标准信息交换用汉字编码(GB2312-80标准),简称国标码。是二字节码,用二个七位二进制数编码表示一个汉字。东南大学C+总程序的开发过程 源程序、目标程序、翻译程序 三种不同类型的翻译程序

16、:汇编程序、编译程序、解释程序 程序的开发过程编辑、编译、连接、运行调试东南大学C+总基本术语 源程序:用源语言写的,有待翻译的程序 目标程序:也称为结果程序,是源程序通过翻译程序加工以后所生成的程序。翻译程序:是指一个把源程序翻译成等价的目标程序的程序。东南大学C+总基本术语 三种不同类型的翻译程序 汇编程序:其任务是把用汇编语言写成的源程序,翻译成机器语言形式的目标程序。编译程序:若源程序是用高级程序设计语言所写,经翻译程序加工生成目标程序,那么,该翻译程序就称为编译程序。东南大学C+总基本术语 三种不同类型的翻译程序 解释程序:这也是一种翻译程序,同样是将高级语言源程序翻译成机器指令。它

17、与编译程序不同点就在于:它是边翻译边执行的,即输入一句、翻译一句、执行一句,直至将整个源程序翻译并执行完毕。东南大学C+总程序的开发过程 编辑 将源程序输入到计算机中,生成后缀为cpp的磁盘文件。编译 将程序的源代码转换为机器语言代码。连接 将多个源程序文件以及库中的某些文件连在一起,生成一个后缀为exe的可执行文件。运行调试东南大学C+总程序开发过程:开始开始编辑源程序编辑源程序编译编译编译错编译错连接连接连接错连接错运行运行运行错运行错完成完成是是是是是是东南大学C+总作业 复习第一章,预习第二章 作业:、东南大学C+总第二章 C+简单程序设计东南大学C+总本章主要内容 C+语言概述 基本

18、数据类型和表达式 数据的输入与输出 算法的基本控制结构 自定义数据类型东南大学C+总2.1.1 C+语言的产生 C+是从C语言发展演变而来的:C语言的开发史源于高级语言和UNIX操作系统的发展要求。早期的系统程序设计,使用的是汇编语言,其优点:(1)能体现计算机硬件指令级的特性,表达能力强;(2)运行效率高。其缺点:可读性,可移植性及描述问题的性能不如高级语言。这样很自然有如下想法:能否用具有足够表达能力的高级语言来进行系统软件的设计呢?Bell实验室做了这一尝试。1970:在 PDP-11/20机上实现了B语言,并用它编写了UNIX系统的实用程序。B-BCPL-CPL-ALGOL 602.1

19、 C+语言概述东南大学C+总 在B语言基础上,改进其缺陷,发展出了C语言,其设计目标:(1)保持BCPL和B的精练性及接近硬件的特点(2)恢复这些语言失去的通用性1972:第一个C编译投入使用1973:UNIX用C改写,加入多道程序功能,发生质变 现在,UNIX已得到广泛推广,成为公认的第一标准的操作系统随着UNIX的进一步开发,C也交织在一起被迅速推广。东南大学C+总 1983:对C扩充,发展为C。C+语言的标准化工作从1989年开始,于1994年制定了ANSI C+标准草案。以后又经过不断完善,成为目前的C+。东南大学C+总2.1.2 C+的特点 全面兼容C 它保持了C的简洁、高效和接近汇

20、编语言等特点 对C的类型系统进行了改革和扩充 C+也支持面向过程的程序设计,不是一个纯正的面向对象的语言 支持面向对象的方法东南大学C+总2.1.3 C+程序实例例2-1/this is a simplest program.#include void main(void)coutHello!n;cout词语句函数程序。字符集是构成语言的基本元素 大小写的英文字母:AZ,az 数字字符:09 特殊字符:空格!#%&*_(下划线)+=-/;.,()东南大学C+总词法记号 词法记号是最小的词法单位、关键字 C+预定义的单词。是指C+中有特殊含义的字,是不能重 新定义的。程序员不可用之作为自己定义的

21、变量或函数的名字。类别类别 关键字个数关键字个数 举例举例 ANSI C 32 ANSI C 32 charchar,for for 等等 ANSI C+61 ANSI C+61 (增加(增加2929个)个)classclass,publicpublic等等 BC/AC BC/AC 扩展了一些扩展了一些 asm asm 等等n、标识符、标识符 程序员声明的单词,它命名程序正文中的程序员声明的单词,它命名程序正文中的n 一些实体。一些实体。东南大学C+总 标识符的构成规则 以大写字母、小写字母或下划线(_)开始。可以由以大写字母、小写字母、下划线(_)或数字09组成。大写字母和小写字母代表不同的

22、标识符。例 Rectangle、Draw、_line.、文字 在程序中直接使用符号表示的数据 包括数字、字符、字符串和布尔文字、操作符 用于实现各种运算的符号。、分隔符 用于分隔各个词法记号或程序正文:(),:;、空白:空格、制表符(TAB键产生的字符)、换行 符(Enter键所产生的字符)和注释的总称。程序书写自由/、/*/东南大学C+总2.2基本数据类型和表达式 2.2.1基本数据类型是程序命令操作的对象是程序命令操作的对象。是指将数据根据表达形式的不同而是指将数据根据表达形式的不同而 划分的类别。划分的类别。数据:数据:数据类型:数据类型:东南大学C+总C+C+的数据类型一般分为如下几种

23、:的数据类型一般分为如下几种:基本数据类型基本数据类型非基本数据类非基本数据类型型(用户定义数据类型)整型整型字符型字符型实型(浮点型)实型(浮点型)逻辑型(布尔型)逻辑型(布尔型)数组数组指针指针空类型空类型结构结构联合联合枚举枚举类类数据类型数据类型东南大学C+总数据类型修饰符:数据类型修饰符:shortshort longlong unsignedunsigned例:无符号整型无符号整型 unsigned int unsigned int 无符号长整型无符号长整型 unsigned longunsigned long 无符号短整型无符号短整型 unsigned shortunsigned

24、 shortsignedsigned东南大学C+总 类型类型 所占位数所占位数 数的范围数的范围 int 16 int 16 -32768 32767-32768 32767 short int 16 short int 16 -32768 32767-32768 32767 long int 32 long int 32 -2147483648 2147483647-2147483648 2147483647 unsigned int 16 unsigned int 16 0 655350 65535 unsigned short 16 unsigned short 16 0 655350

25、65535 unsigned long 32 unsigned long 32 0 42949672950 4294967295至于它们之间的差异,请看下表至于它们之间的差异,请看下表(p(p):(16(16位计算机)位计算机)东南大学C+总0111111111111111.3145678923+数符小数部分指数东南大学C+总u例:例:ucout“size of int is“size of(int)endl;C+C+强类型语言强类型语言要求程序设计者在使用数据之前对数要求程序设计者在使用数据之前对数据的类型进行声明。据的类型进行声明。注意:注意:(1 1)整型和实型的几种不同方式)整型和实型

26、的几种不同方式(2 2)注意各种数据类型的取值范围。)注意各种数据类型的取值范围。(3 3)注意)注意C C无布尔类型。无布尔类型。C C语言在表达逻辑运算的结果时,用语言在表达逻辑运算的结果时,用 整数整数0 0 代表逻代表逻辑辑“假假”,用非,用非0 0的整数值的整数值(如如1)1)表示逻辑表示逻辑“真真”。C+C+中增添了布尔类型中增添了布尔类型boolbool,但并非每个但并非每个C+C+编译器都支持编译器都支持。用用size of(数据类型)可以确定数据类型的字节长度(数据类型)可以确定数据类型的字节长度 东南大学C+总#includevoid main(void)const int

27、 PRICE=30;int num,total;float v,r,h;num=10;total=num*PRICE;couttotal endl;r=2.5;h=3.2;v=3.14159*r*r*h;coutv=Aif(c=Ac=Z)c=c+a-A;c=Z)c=c+a-A;将字符变量将字符变量c c从大写字母转为小写字母。从大写字母转为小写字母。例例2 2:0-0=0 1-0=1 1-0=1 2-0=2 2-0=2 如果如果c c是一数字字符,则是一数字字符,则c-0c-0就是它对应数字的数值就是它对应数字的数值3 3、字符常量字符常量东南大学C+总非图形字符非图形字符(如回车、制表符等如

28、回车、制表符等)及及“等字符,因它们有特殊作用,等字符,因它们有特殊作用,所以表示这些字符本身时,应:所以表示这些字符本身时,应:p p。n n 表换行表换行无论是不可显示字符还是一般字符,都可用无论是不可显示字符还是一般字符,都可用8 8进制数、进制数、1616进制数表示进制数表示 dddddd:一:一 至三位至三位8 8进制数。进制数。xhh:xhh:一一 至二位至二位1616进制数。进制数。例如:例如:001001表示码值为表示码值为(01)(01)8 8 的的ASCIIASCII字符。字符。AA也可用也可用101101表示表示 00为空白符,即为空白符,即NULLNULL,码值为,码值

29、为0 0,在,在C C语言中是字符串语言中是字符串的结束标志。的结束标志。(与与00和空格符不同和空格符不同)例:例:cout“x07operatingtsystemn”;cout“x07operatingtsystemn”;operating operating systemsystem转义字符转义字符东南大学C+总例例 :int a=b;int a=b;char c=97;char c=97;coutaendl;coutaendl;coutcendl;coutcendl;输出:输出:9898 a an字符数据的使用方法字符数据的使用方法u字符数据和整型数据之间字符数据和整型数据之间可以运算

30、。可以运算。u字符数据与整型数据可以字符数据与整型数据可以互相赋值。互相赋值。东南大学C+总4 4、字符串常量字符串常量字符串型常量字符串型常量是用双引号括起来的一个或多个字符。是用双引号括起来的一个或多个字符。例如,将例如,将1 1用双引号括起来,此时用双引号括起来,此时“1 1”代表的是一个字符串型常量,代表的是一个字符串型常量,与字符型常量与字符型常量1 1也是有区别的。也是有区别的。C+C+规定以字符规定以字符00作为字符串结束标志。如,一个字符串作为字符串结束标志。如,一个字符串“HELLOHELLO”,在内存中,在内存中以以“00”为结尾。为结尾。“0”0”在输出时不作显示,只用来

31、表示字符串的结束。在输出时不作显示,只用来表示字符串的结束。字符串型常量字符串型常量“HELLOHELLO”H E L L O H E L L O 0 0 注意注意“P”P”与与PP不同。前者为字符串,在机内存储形式不同。前者为字符串,在机内存储形式为为 P 0P 0 ,而,而PP就是一常数就是一常数P P。东南大学C+总define PI 3.14159define PI 3.14159main()main()int r;int r;float L,S;float L,S;r=10;r=10;L=2 L=2*PI PI*r;r;S=PI S=PI*r r*r;r;printf(“printf

32、(“周长周长=%fn”,L);=%fn”,L);printf(“printf(“面积面积=%fn”,S);=%fn”,S);这是一个知道圆半径这是一个知道圆半径r r,求圆周长,求圆周长L L、圆面积、圆面积S S的简单的简单C C程序。其中的程序。其中的PIPI就是符号常量,它的值在一开始就就是符号常量,它的值在一开始就被预处理命令被预处理命令“#define#define”定义为实数定义为实数3.141593.14159了了,故故程序在运行和编译时会自动用程序在运行和编译时会自动用“3.141593.14159”来替代来替代PIPI。符号常量比起一般常量来,不但使用方便,实际符号常量比起一

33、般常量来,不但使用方便,实际值容易修改,而且更形象化,便于记忆。值容易修改,而且更形象化,便于记忆。符号常量东南大学C+总布尔型数据布尔型数据n布尔型变量的说明:布尔型变量的说明:例:例:bool flag;n布尔型数据的取值:布尔型数据的取值:只有只有 false 和和 true 两个值两个值东南大学C+总*C+C+中:中:const float pi=3.14159;const float pi=3.14159;*常量定义中初始化的值可以是一个常量表达式:常量定义中初始化的值可以是一个常量表达式:const int size=100const int size=100*sizeof(int

34、);sizeof(int);const int number=max(15,23);const int number=max(15,23);(错)(错)注意:注意:#define#define 与与constconst的区别的区别东南大学C+总2.2.3 3变量变量变量是什么变量是什么变量变量程序在运行过程中,其值会发生改变程序在运行过程中,其值会发生改变的量。的量。变量:变量值变量:变量值 2323变量名变量名 lengthlength变量类型变量类型 intint东南大学C+总C+C+规定必须以字母或下划线打头,后面跟字母、数字或下划线规定必须以字母或下划线打头,后面跟字母、数字或下划线(

35、如:如:a3,Z_5e,a3,Z_5e,_D7d_D7d等等),),并且不能与保留字、函数名、类名等并且不能与保留字、函数名、类名等C+C+专用名相同专用名相同(如如 char,for,char,for,int int 等等)。注意:注意:(a)(a)长度:早期的长度:早期的C C编译程序只认前编译程序只认前8 8个字符。个字符。VCVC允许允许256256个字符。个字符。但但一般不要超过一般不要超过3131个字符为宜个字符为宜 1 1、命名、命名东南大学C+总(b)(b)约定:约定:变量名、函数名、和数据类型名等用小写字母变量名、函数名、和数据类型名等用小写字母 自定义的类型名(如类)、自定

36、义的类型名(如类)、符号常量名及宏符号常量名及宏 用大写字母;用大写字母;下划线开头的名字常为系统程序下划线开头的名字常为系统程序(库函数用库函数用),用户一般不用。用户一般不用。(c)(c)要要有意义:如用有意义:如用SumSum表示表示“求和变量求和变量”,不要用,不要用aaaaaa,A1A1,B12B12之类名字。之类名字。例:例:my_car my_car 小写小写 my_Car my_Car 骆驼骆驼 iMyCar iMyCar 匈牙利标识法(匈牙利标识法(WINDOWSWINDOWS标准命名法标准命名法)东南大学C+总下面我们看一段关于变量的程序:下面我们看一段关于变量的程序:程序

37、中的程序中的num1,num2num1,num2和和sumsum都是变量。它都是变量。它们的值在程序的运行过程中都发生了变们的值在程序的运行过程中都发生了变化。变量定义后,各变量的初值都是不化。变量定义后,各变量的初值都是不确定的。确定的。num1num1的第一个确切值是的第一个确切值是1010,当,当再次给再次给num1num1赋值时,赋值时,num1num1的值又变成的值又变成-5-5。其他两个变量的变化情况类似。其他两个变量的变化情况类似。#include#includevoid main()void main()int num1,num2,sum;int num1,num2,sum;n

38、um1=10;num2=25;num1=10;num2=25;sum=num1+num2;sum=num1+num2;cout“sum=“sumendcout“sum=“sumendl;l;num1=-5;num2=num1+3;num1=-5;num2=num1+3;sum=num1+num2;sum=num1+num2;cout“sum=“sumendcout“sum=“sumendl;l;东南大学C+总变量:需要定义,说明其存储属性和数据类型变量:需要定义,说明其存储属性和数据类型。存储属性类型区分符变量名赋初值 ;,staticexternregisterautointcharfloa

39、tdouble 例:例:static int nward=0,nkayword;static int nward=0,nkayword;同一语句中,不能混合定义不同类型的变量。同一语句中,不能混合定义不同类型的变量。2 2、变量的定义变量的定义东南大学C+总变量的存储类型变量的存储类型nauto存储类存储类u属于一时性存储,其存储空间可以被若干变属于一时性存储,其存储空间可以被若干变量多次覆盖使用。量多次覆盖使用。nregister存储类存储类u存放在通用寄存器中。存放在通用寄存器中。nextern存储类存储类u在所有函数和程序段中都可引用。在所有函数和程序段中都可引用。nstatic存储类存

40、储类u在内存中是以固定地址存放的,在整个程序在内存中是以固定地址存放的,在整个程序运行期间都有效。运行期间都有效。东南大学C+总 (1)double area,radius=23;(1)double area,radius=23;(2)double area,radius;(2)double area,radius;radius=23;radius=23;3 3、变量赋值与初始化、变量赋值与初始化东南大学C+总 表达式:一个常量或标识对象的标识符是一个最简单的表达式,其值是常量或对象的值 一个表达式的值可以用来参与其它操作,即用作其它运算符的操作数,这就形成了更复杂的表达式 包含在括号中的表达

41、式仍是一个表达式,其类型和值于未加括号时的表达式相同 算术表达式:由算术运算符、操作数和括号构成的表达式称为算术表达式 a+b+(c-b)/2+5Page 104东南大学C+总n、基本算术运算符、基本算术运算符 +-*/%(取余)(取余)(若整数相除,结果取整若整数相除,结果取整)n优先级与结合性优先级与结合性先乘除,后加减,同级自左至右先乘除,后加减,同级自左至右东南大学C+总(1)/整除 5/2=2 5.0/2.0=2.5 若/的两操作数都为整数,则为整除:例 int i=15;float f ;f=i/10;结果为:f=1 如果将第三条语句改为 f=(float)i/10;或f=i/10

42、.0;则结果为:f=1.5东南大学C+总 在在 C+C+语言中,表达式语言中,表达式 (7/3+17/3+1)+5/6+5/6 的值是(的值是()。)。A A)2 2B B)3 3C C)4 4 D D)不能确定)不能确定B东南大学C+总 (余的符号与被除数相同,不允许对浮点数操作余的符号与被除数相同,不允许对浮点数操作)3%4=3 4%4=0 3%4=3 4%4=0 例例#include#include void main()void main()int n;int n;n=40%5;n=40%5;cout 40%5:n endl;/cout 40%5:n endl;/(0 0)n=40%7

43、;n=40%7;cout 40%7:n endl;/cout 40%7:n endl;/(5 5)n=40%-7;n=40%-7;cout 40%-7:n endl;/cout 40%-7:n endl;/(5 5)n=-40%7;n=-40%7;cout -40%7:n endl;/cout -40%7:n endl;/(-5-5)n=-40%-7;cout -40%-7:n endl;/n=-40%-7;cout -40%-7:n endl;/(-5-5)(2.2.)%取余取余东南大学C+总()()取作为表达式的值,然后取作为表达式的值,然后()()先;然后取作为表达式的值先;然后取作为表

44、达式的值()()取;取;()(),取,取例:例:int a=3;int a=3;int b=+a;int b=+a;coutacouta“bendl;bendl;int c=a+;int c=a+;coutacouta“cendl;cendl;45 4、增量和减量,、增量和减量,东南大学C+总.赋值运算=赋值运算符用于将一个数据传给一个变量。例如:int x;x=5;将值 5 传给变量 x。其中=号即赋值运算符。A:(1)双目运算符,从右到左 d=a=b (2)赋值操作是一个表达式,每个表达式在求值后都有一个确定的值,其值为赋值号左边表达式的值 例:cout(x=5)endl;(3)当赋值号两

45、边类型不一至时,根据左边类型转东南大学C+总int a=10;float x=70000.5;int a=10;float x=70000.5;x=a;x=a;将将 a a 的值的值 10 10 赋给赋给 x x,x x 的值为的值为 10.010.0。lint a=10;float x=70000.5;a=x;int a=10;float x=70000.5;a=x;将将 x x 的值的值 70000.5 70000.5 赋给赋给 a a,但,但 70000.5 70000.5 超过了超过了 int int 的取值范围,于是将超过的部分扔掉了,的取值范围,于是将超过的部分扔掉了,a a 是多

46、是多少不知道了。少不知道了。l特别注意,上面的赋值语句,编译时是可以通过的。特别注意,上面的赋值语句,编译时是可以通过的。东南大学C+总有10种复合运算符:+=,-=,*=,/=,%=,=,&=,=,|=例:a+=3 等价于 a=a+3 x*=y+8 等价于 x=x*(y+8)东南大学C+总a=5表达式值为5a=b=c=5表达式值为5,a,b,c均为5a=5+(c=6)表达式值为11,a为11,c为6a=(b=4)+(c=6)表达式值为10,a为10,b为4,c为6a=(b=10)/(c=2)表达式值为5,a为5,b为10,c为2a+=a-=a*a 相当于:a=a+(a=a-a*a)Page

47、113东南大学C+总例:例:x=6;x=6;x+=x-=x x+=x-=x*x;x;若若x x为整型变量,则上述语句执行后为整型变量,则上述语句执行后 x x 的值是的值是_(4)_(4)_。A.36 B.-60A.36 B.-60C.60C.60D.-24D.-24B东南大学C+总 格式:表达式1,表达式2 求解顺序及结果:先求解1,再求解2,最终结果为表达式2的值 例a=3*5,a*4 最终结果为60例 2 int a,b,c;d=(a=1,b=a+2,c=b+3);coutdendl;Page 115东南大学C+总、关系运算与关系表达式 用关系运算符将两个表达式连接起来,就是关系表达式

48、关系运算是比较简单的一种逻辑运算,优先次序为:=!=优先级相同(高)优先级相同(低)关系表达式是一种最简单的逻辑表达式其结果类型为 bool,值只能为 true 或 false。例如:ab,cb)&(xy)其结果类型为 bool,值只能为 true 或 false。东南大学C+总 a !a truefalsefalse trueab a&b111100010000ab a|b111101011000东南大学C+总优先级:优先级:!;*/%/%;+-+-;=;=!=;=!=;&|东南大学C+总n注意:注意:n(1 1)比较运算符)比较运算符n与与n()()n“”;n()()n“”;n(2 2)不

49、等于运算符)不等于运算符n(!)n(!)(!)东南大学C+总()逻辑非()逻辑非(!()(!()例!例!c c若,若,(!(!c c)()()!()!()()()若写成从左到右若写成从左到右 (衡为(衡为1 1)东南大学C+总例:例:ay|ab-!cay|ab-!c (ay)|(a(b-(!c)(ay)|(a(b-(!c)若若x,y,zx,y,z的初值均为的初值均为1,1,则执行表达式则执行表达式w=+x|+y&+z w=+x|+y&+z 后后,x,y,z,x,y,z的值分别为的值分别为_。A A)x=1,y=1,z=2 Bx=1,y=1,z=2 B)x=2,y=2,z=2x=2,y=2,z=

50、2 C C)x=2,y=1,z=2 Dx=2,y=1,z=2 D)x=2,y=1,z=1 (D)x=2,y=1,z=1 (D)东南大学C+总 一般形式:表达式1?表达式2:表达式3表达式1 必须是 bool 类型 执行顺序:先求解表达式1,若表达式1的值为true,则求解表达式2,表达式2的值为最终结果 若表达式1的值为false,则求解表达式3,表达式3的值为最终结果例例 x=ab?a:b x=ab?a:b 该例是该例是IFELSEIFELSE语句的一个替代语句的一个替代 if(ab)if(ab)?a:b+1max=(ab)?a:b+1l (2)(2)条件运算符的结合性为条件运算符的结合性为

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

当前位置:首页 > 办公、行业 > 各类PPT课件(模板)
版权提示 | 免责声明

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


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

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


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