C程序语言设计课件第二章.ppt
《C程序语言设计课件第二章.ppt》由会员分享,可在线阅读,更多相关《C程序语言设计课件第二章.ppt(88页珍藏版)》请在三一文库上搜索。
1、第二章 C+简单程序设计,C+语言程序设计,2,本章主要内容,C+语言概述 基本数据类型和表达式 数据的输入与输出 算法的基本控制结构 自定义数据类型,3,C+语言的产生,C+是从C语言发展演变而来的,首先是一个更好的C 引入了类的机制,最初的C+被称为“带类的C” 1983年正式取名为C+ 从1989年开始C+语言的标准化工作 于1994年制定了ANSI C+标准草案 于1998年11月被国际标准化组织(ISO)批准为国际标准,成为目前的C+,C+语言概述,4,C+的特点,全面兼容C 它保持了C的简洁、高效和接近汇编语言等特点 对C的类型系统进行了改革和扩充 C+也支持面向过程的程序设计,不
2、是一个纯正的面向对象的语言 支持面向对象的方法,C+语言概述,5,C+程序实例例2-1,/2_1.cpp #include using namespace std; void main(void) cout“Hello!n“; cout“Welcome to c+!n“; 运行结果: Hello! Welcome to c+!,C+语言概述,6,C+字符集,大小写的英文字母:AZ,az 数字字符:09 特殊字符: 空格 ! # % . , () ,C+语言概述,7,词法记号,关键字 C+预定义的单词 标识符 程序员声明的单词,它命名程序正文中的一些实体 文字 在程序中直接使用符号表示的数据 操
3、作符 用于实现各种运算的符号 分隔符 () , : ; 用于分隔各个词法记号或程序正文 空白符 空格、制表符(TAB键产生的字符)、换行符(Enter键所产生的字符)和注释的总称,C+语言概述,8,标识符的构成规则,以大写字母、小写字母或下划线(_)开始。 可以由以大写字母、小写字母、下划线(_)或数字09组成。 大写字母和小写字母代表不同的标识符。,C+语言概述,9,数据类型 常量与变量,#include using namespace std; void main(void) const int PRICE=30; int num,total; float v ,r,h; num=10;
4、total=num*PRICE; couttotal endl; r=2.5; h=3.2; v=3.14159*r*r*h; coutv endl; ,Page 9,基本数据类型和表达式,10,#include using namespace std; void main(void) const int 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 endl; ,数据类型 整型数据,整型常量,short u
5、nsigned short 2字节 int、unsigned int 4字节 long unsigned long 4字节,整型变量,基本数据类型和表达式,11,数据类型 整型数据及取值范围,类型 说明符 位数 数值范围 短整 short 16 -3276832767 基本 int 32 -231(231-1) 长整 long 32 -231(231-1) 无符号 unsigned short 16 065535 unsigned int 32 0(232-1) unsigned long 32 0(232-1),基本数据类型和表达式,12,#include using namespace s
6、td; void main(void) const int PRICE=30; int num,total; float v ,r,h; num=10; total=num*PRICE; couttotalendl; r=2.5; h=3.2; v=3.14159*r*r*h; coutvendl; ,数据类型 实型数据,实型常量,float 4字节 3.41038 7位有效数字 double 8字节 1.710308 15位有效数字 long double 8字节 1.710308 15位有效数字,实型变量,缺省为double型 后缀 F(或 f) 为 float型 后缀 L(或 l) 为
7、long double 型,基本数据类型和表达式,13,数据类型 字符型数据(一),字符常量 单引号括起来的一个字符,如:a, D, ?, $ 字符变量 用来存放字符常量 例:char c1,c2; c1=a; c2=A; 字符数据在内存中的存储形式 以ASCII码存储,占1字节,用7个二进制位,Page 13,基本数据类型和表达式,14,字符数据的使用方法 字符数据和整型数据之间可以运算。 字符数据与整型数据可以互相赋值。 字符串常量 例:“CHINA“ “a“ a 所以:char c; c=“a“;,Page 14,数据类型 字符型数据(二),基本数据类型和表达式,15,数据类型 布尔型数
8、据,布尔型变量的说明: 例:bool flag; 布尔型数据的取值: 只有 false 和 true 两个值,基本数据类型和表达式,16,数据类型 变量初始化,例: int a=3; double f=3.56; char c=a; int c(5);,Page 16,基本数据类型和表达式,17,数据类型 混合运算时的类型转换,不同类型数据进行混合运算时,C+编译器会自动进行类型转换。 为了避免不同的数据类型在运算中出现类型问题,应尽量使用同种类型数据。 可以采用强制类型转换: 例如: float c; int a,b; c=float(a)/float(b); 或 c= (float)a/(
9、float)b;,基本数据类型和表达式,18,变量的存储类型,auto 属于一时性存储,其存储空间可以被若干变量多次覆盖使用。 register 存放在通用寄存器中。 extern 在所有函数和程序段中都可引用。 static 在内存中是以固定地址存放的,在整个程序运行期间都有效。,基本数据类型和表达式,19,算术运算符与算术表达式,基本算术运算符 + - * / (若整数相除,结果取整) %(取余,操作数为整数) 优先级与结合性 先乘除,后加减,同级自左至右 +, -(自增、自减) 例:i+; - j;,Page 19,基本数据类型和表达式,20,赋值运算符和赋值表达式 简单的赋值运算符“=
10、“,举例 n=n+5 表达式的类型 等号左边对象的类型 表达式的值 等号左边对象被赋值后的值,Page 20,基本数据类型和表达式,21,赋值运算符和赋值表达式 复合的赋值运算符,有10种复合运算符: +=, -=, *=, /=, %=, =,&=,=,|= 例 a+=3 等价于 a=a+3 x*=y+8 等价于 x=x*(y+8),基本数据类型和表达式,22,赋值运算符和赋值表达式 赋值表达式举例,a=5 表达式值为5 a=b=c=5 表达式值为5,a,b,c均为5 a=5+(c=6) 表达式值为11,a为11,c为6 a=(b=4)+(c=6) 表达式值为10,a为10,b为4,c为6
11、a=(b=10)/(c=2) 表达式值为5,a为5,b为10,c为2 a+=a-=a*a 相当于 a=a+(a=a-a*a),Page 22,基本数据类型和表达式,23,逗号运算和逗号表达式,格式 表达式1,表达式2 求解顺序及结果 先求解1,再求解2,最终结果为表达式2的值 例 a=3*5 , a*4 最终结果为60,Page 23,基本数据类型和表达式,24,关系运算与关系表达式,关系运算是比较简单的一种逻辑运算,优先次序为: = = != 优先级相同(高) 优先级相同(低) 关系表达式是一种最简单的逻辑表达式 其结果类型为 bool,值只能为 true 或 false。 例如:ab,c=
12、a+b,x+y=3,基本数据类型和表达式,25,逻辑运算与逻辑表达式,逻辑运算符 !(非) &(与) |(或) 优先次序: 高 低 逻辑表达式 例如:(ab)&(xy) 其结果类型为 bool,值只能为 true 或 false,基本数据类型和表达式,26,条件运算符与条件表达式,一般形式 表达式1?表达式2:表达式3 表达式1 必须是 bool 类型 执行顺序 先求解表达式1, 若表达式1的值为true,则求解表达式2,表达式2的值为最终结果 若表达式1的值为false,则求解表达式3,表达式3的值为最终结果 例: x=ab? a:b;,基本数据类型和表达式,27,条件运算符与条件表达式,注
13、意: 条件运算符优级高于赋值运算符,低于逻辑运算符 表达式2、3的类型可以不同,条件表达式的最终类型为 2 和 3 中较高的类型。 例: x=ab? a:b;,基本数据类型和表达式,28,sizeof 运算符,语法形式 sizeof (类型名) 或 sizeof (表达式) 结果值: “类型名”所指定的类型或“表达式”的结果类型所占的字节数。 例: sizeof(short) sizeof(x),基本数据类型和表达式,29,位运算按位与(&),运算规则 将两个运算量的每一个位进行逻辑与操作 举例:计算 3 ,基本数据类型和表达式,30,位运算按位或(|),运算规则 将两个运算量的每一个位进行逻
14、辑或操作 举例:计算 3 | 5 3: 0 0 0 0 0 0 1 1 5:(|) 0 0 0 0 0 1 0 1 3 | 5: 0 0 0 0 0 1 1 1 用途: 将某些位置1,其它位不变。 例如:将 int 型变量 a 的低字节置 1 : a = a | 0xff;,基本数据类型和表达式,31,位运算按位异或(),运算规则 两个操作数进行异或: 若对应位相同,则结果该位为 0, 若对应位不同,则结果该位为 1, 举例:计算 071052 071: 0 0 1 1 1 0 0 1 052: () 0 0 1 0 1 0 1 0 071052 : 0 0 0 1 0 0 1 1,基本数据类
15、型和表达式,32,位运算按位异或(),用途: 使特定位翻转(与0异或保持原值,与1异或取反) 例如:要使 01111010 低四位翻转: 0 1 1 1 1 0 1 0 () 0 0 0 0 1 1 1 1 0 1 1 1 0 1 0 1,基本数据类型和表达式,33,位运算取反(),单目运算符,对一个二进制数按位取反。 例: 025:0000000000010101 025:1111111111101010,基本数据类型和表达式,34,位运算移位,左移运算() 右移后,低位:舍弃 高位:无符号数:补0 有符号数:补“符号位”,基本数据类型和表达式,35,运算符优先级,括号 +,-,sizeof
16、 *, /, % +, - =, != 位运算 & | ?: 赋值运算 逗号运算,低,高,基本数据类型和表达式,36,混合运算时数据类型的转换 隐含转换,一些二元运算符(算术运算符、关系运算符、逻辑运算符、位运算符和赋值运算符)要求两个操作数的类型一致。 在算术运算和关系运算中如果参与运算的操作数类型不一致,编译系统会自动对数据进行转换(即隐含转换),基本原则是将低类型数据转换为高类型数据。 char short int unsigned long unsigned long float double 低 高,基本数据类型和表达式,37,混合运算时数据类型的转换 隐含转换,当参与运算的操作数必
17、须是bool型时,如果操作数是其它类型,编译系统会自动将非0数据转换为true,0转换为false。 位运算的操作数必须是整数,当二元位运算的操作数是不同类型的整数时,也会自动进行类型转换, 赋值运算要求左值与右值的类型相同,若类型不同,编译系统会自动将右值转换为左值的类型。,基本数据类型和表达式,38,混合运算时数据类型的转换 强制类型转换,语法形式: 类型说明符(表达式) 或 (类型说明符)表达式 强制类型转换的作用是将表达式的结果类型转换为类型说明符所指定的类型。,基本数据类型和表达式,39,语句,声明语句 表达式语句 选择语句 循环语句 跳转语句 复合语句 标号语句,40,表达式语句,
18、格式: 表达式; 表达式语句与表达式的区别: 表达式可以包含在其它表达式中,而语句不可。 例:if (a=b)0) t=a; 不可写为:if (a=b;)0) t=a;,语 句,41,复合语句,将多个语句用一对大括号包围,便构成一个复合语句 例如 sum=sum+i; i+; ,语 句,42,简单的输入、输出,向标准输出设备(显示器)输出 例:int x; coutx;,43,顺序结构 分支结构 循环结构,算法的基本控制结构,44,如何解决分支问题?,例2-2 输入一个年份,判断是否闰年。,算法的基本控制结构,#include using namespace std; void main(vo
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序语言 设计 课件 第二
链接地址:https://www.31doc.com/p-2142503.html