700 likes | 844 Views
第 6 章 基本的程序语句. 本章知识点: 预备知识 数据类型及取值范围 标识符、常量与变量 不同类型数据间的转换 运算符和表达式 标准输入输出函数. 计算机中数的表示及进制转换 数码、基与权 数码:表示数的符号 基:数码的个数 权:每一位所具有的值 数制. 6.0 预备知识. 进制之间的转换. 二进制转换成十进制 ( 整数 + 小数 ) 方法:按权相加. 十六进制数. 数制. 十进制数. 二进制数. 八进制数. 数码. 0~9. 0~1. 0~7. 0~9,A~F,a~f. 基. 10. 2. 8. 16. 权.
E N D
第6章 基本的程序语句 本章知识点: 预备知识 数据类型及取值范围 标识符、常量与变量 不同类型数据间的转换 运算符和表达式 标准输入输出函数
计算机中数的表示及进制转换 数码、基与权 数码:表示数的符号 基:数码的个数 权:每一位所具有的值 数制 6.0预备知识
进制之间的转换 • 二进制转换成十进制(整数+小数) 方法:按权相加
十六进制数 数制 十进制数 二进制数 八进制数 数码 0~9 0~1 0~7 0~9,A~F,a~f 基 10 2 8 16 权 10º,10¹,10²,… 2º,2¹,2²,… 8º,8¹,8²,… 16º,16¹,16²,… 表示 特点 逢十进一 逢二进一 逢八进一 逢十六进一 十六进制:81AE=816³+116² +1016¹+1416º 八进制:4275=48³+28² +78¹+58º 十进制:4956= 410³+910² +510¹+610º 二进制:1011=12³+02² +12¹+12º
十进制转换成二进制 • 方法:(整数部分) • 连续除以2,从低到高记录余数,直至商为0 • 方法:(小数部分) • 连续乘以2,从高到低记录整数,直至余下的小数为0或者满足精度要求 例 把十进制数7转换成二进制数 7 2 余1 余1 2 3 (7)10=(0111)2 2 1 余 1 0 余 0 例 ( 0.625)10=(0.101)2
0 1 2 3 4 5 7 6 7 6 5 4 3 2 1 0 7 6 8 5 9 4 10 3 ……... 2 1 字节和位 • 内存以字节为单元组成 • 每个字节有一个地址 • 一个字节一般由8个二进制位组成 • 每个二进位的值是0或1
数值的表示方法——原码、反码和补码 • 原码:最高位为符号位(0正数,1负数),其余各位为数值本身的绝对值 • 反码: • 正数:反码与原码相同 • 负数:符号位为1,其余位对原码取反 • 补码: • 正数:原码、反码、补码相同 • 负数:最高位为1,其余位为原码取反,再对整个数加1
(用一字节8位表示数) 原码 反码 补码 +7 00000111 00000111 00000111 -7 10000111 11111000 11111001 +0 00000000 00000000 00000000 -0 10000000 11111111 00000000 正0代表数字0 负0代表-128 (规定) • 负数补码转换成十进制数:最高位不动,其余位取反加1 例 补码:11111001 取反:10000110 加1: 10000111=-7
定点数与浮点数 • 定点数:小数点位置固定的数,(整数与纯小数) • 浮点数:小数点位置是浮动的 (有整数和小数)单精度和双精度 例 234 ,256 ,0.123 ,0.0056 是定点数 例 61.329是浮点数 表示方法见P11
整 型 基本类型 单精度型float 实型 双精度型double 字符类型char 数组 短整型short 结构体struct C 数 据 类 型 整型int 共用体union 构造类型 长整型long 枚举类型enum 指针类型 空类型void 定义类型typedef 6.1数据类型及取值范围 • 数据类型总表 数据类型决定: 1. 数据占内存字节数 2. 数据取值范围 3. 其上可进行的操作
基本数据类型 类型 符号 关键字 数的表示范围 所占位数 (signed)int 16 -32768~32767 16 (signed)short -32768~32767 32 (signed)long -2147483648~2147483647 unsignedint 16 0~65535 unsignedshort 16 0~65535 unsignedlong 32 0~4294967295 32 float 有 3.4e-38~3.4e38 64 有 double 1.7e-308~1.7e308 8 有 char -128~127 无 8 0~255 unsigned char 有 整型 无 实型 字符型 说明:数据类型所占字节数随机器硬件不同而不同,上表以IBM PC机为例: 请看int和unsigned int
int型: 最大:32767 01 11 11 11 11 11 11 11 10 00 00 00 00 00 00 00 11 11 11 11 11 11 11 11 最小:-32768 unsigned int型: 最大:65535 00 00 00 00 00 00 00 00 最小:0
b=b-6; m=m*10+10; t=t*10; printf("After change:\n"); printf("a+4=%d\n",a); printf("b-6=%d\n",b); printf("m*10+10=%u\n",m); printf("t*10=%e\n",t); } • 例1:运行下面的程序,了解变量的取值范围和C语言的特性。 /*example6_1.c 变量的取值范围测试*/ #include <stdio.h> main() { int a=32766,b=-32766; unsigned m=6553; float t=3.4e+37; printf("a=%d\n",a); printf("m=%u\n",m); printf(“t=%e\n”,t); a=a+4;
标识符 定义:用来标识变量、常量、函数等的字符序列 组成: 只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线 大小写敏感 不能使用关键字 长度:最长32个字符 命名原则: 见名知意 不宜混淆 如l与I, o与0 6.2标识符、变量与常量 • 例:判断下列标识符号合法性 • sum Sum M.D.John day Date 3days • student_name #33 lotus_1_2_3 • char a>b _above $123 3days M.D.John #33 char a>b $123 < >
变量 概念:其值可以改变的量 变量名与变量值 变量定义的一般格式: 数据类型 变量1[,变量2,…,变量n]; int a=1, b=-3,c; 地址 地址 地址 …... main() { int a,b=2; a=1; float data; data=(a+b)*1.2; printf(“data=%f\n”,data); } 1 a 2字节 变量定义 b -3 可执行语句 2字节 main() { int a,b=2; float data; a=1; data=(a+b)*1.2; printf(“data=%f\n”,data); } c 2字节 …... 随机数 内存 编译程序根据变量定义为其 分配指定字节的内存单元 • 变量初始化:定义时赋初值 例: int a,b,c; float data; • 变量的使用:先定义,后使用 决定分配字节数 和数的表示范围 合法标识符 例: int a=2,b,c=4; float data=3.67; char ch=‘A’; int x=1,y=1,z=1; int x=y=z=1; • 变量定义位置:一般放在函数开头 例1 int student; stadent=19; //Undefined symbol ‘stadent’ in function main 例2 float a,b,c; c=a%b; //Illegal use of floating point in function main
占字节数随机器不同而不同,一般占一个机器字占字节数随机器不同而不同,一般占一个机器字 short≤int≤long 可用sizeof(类型标识符)测量 整型变量 • 实型变量 • float:占4字节,提供7位有效数字 • double:占8字节,提供15~16位有效数字 例1: float a; a=111111.111; /* a=111111.1*/ 例2: double b; b=111111.111; /* b=111111.111*/ • 字符型变量 • 字符变量存放字符ASCII码 • char与int数据间可进行算术运算 例 a=‘D’; /* a=68; */ x=‘A’+5; /* x=65+5; */ s=‘!’+‘G’ /* s=33+71; */ 没有字符串变量,用字符数组存放
例子 宏定义 变量定义 输出结果 /*example6_2.c*/ #define PRICE 12.5 main() { int num=3; float total; char ch1,ch2=‘D’; total=num*PRICE; ch1=ch2-‘A’+‘a’; printf(“total=%f,ch1=%c\n”,total,ch1); } 运行结果: total=37.500000, ch1=d
常量 • 定义:程序运行时其值不能改变的量(即常数) • 分类: • 符号常量:用标识符代表常量 • 定义格式: #define符号常量 常量 • 一般用大写字母 • 是宏定义预处理命令,不是C语句 • 直接常量: • 整型常量 请点击: • 实型常量 请点击: • 字符常量 请点击: • 字符串常量 请点击: 例 符号常量举例 #define PRICE 30 main() { int num,total; num=10; total=num*PRICE; printf("total=%d",total); } 如 #define PRICE 30 运行结果:total=300 < >
整型常量(整常数) 问题: 0123 = ( )10 0x123 = ( )10 0Xff = ( )10 83 291 255 • 三种形式: • 十进制整数:由数字0~9和正负号表示.如 123,-456,0 • 八进制整数:由数字0开头,后跟数字0~7表示.如0123,011 • 十六进制整数:由0x开头,后跟0~9,a~f,A~F表示. 如0x123,0Xff 问题: 0123 = ( )10 0x123 = ( )10 0Xff = ( )10 • 整型常量的类型 • 根据其值所在范围确定其数据类型 • 在整常量后加字母l或L,认为它是long int型常量 例 30000 为int型 65536 为long int 型 例 12 与 12L
例3:了解整型常量的不同进制表示法。 /*example6_3.c */ #include<stdio.h> main() { printf("十六进制0x80的十进制值为:%d\n",0x80); printf("八进制0200的十进制值为:%d\n",0200); printf("十进制128的十进制值为:%d\n",128); printf("十进制128的十六进制值为:%x\n",128); printf("十进制128的八进制值为:%o\n”,128); }
实型常量(实数或浮点数) • 表示形式: • 十进制数形式:(必须有小数点) 如0.123, .123, 123.0, 0.0, 123. • 指数形式:(e或E之前必须有数字;指数必须为整数)如12.3e3 ,123E2, 1.23e4 , e-5 , 1.2E-3.5 • 实型常量的类型 • 默认double型 • 在实型常量后加字母f或F,认为它是float 型
字符常量 • 转义字符及其含义: 转义字符 含义 转义字符 含义 \t \n 换行 水平制表 垂直制表 \b 退格 \v \r 回车 \f 换页 \a 响铃 \\ 反斜线 \‘ 单引号 \“ 双引号 < 2位16进制数代表的字符 \ddd 3位8进制数代表的字符 \xhh • 定义:用单引号括起来的单个普通字符或转义字符. 如 ‘a’ ‘A’ ‘?’ ‘\n’ ‘\101’ • 字符常量的值:该字符的ASCII码值 • 转义字符:反斜线后面跟一个字符或一个代码值表示 如 ‘A’——65, ‘a’——97, ‘0’——48 , ‘\n’——10 例 转义字符举例 /*example2_4.c */ main() { printf("\101 \x42 C\n"); printf("I say:\"How are you?\"\n"); printf("\\C Program\\\n"); printf("Turbo \'C\'"); } 例: ‘A’-------’\101’-------’\x41’--------65 如 ‘\101’ -----------‘A’ ‘\012’ -----------’\n’ ‘\376’ -----------’’ ‘\x61’ -----------’a’ ‘\060’ -----------’0’ ‘\483’ ----------() 运行结果:(屏幕显示) A B C Isay:”How are you?” \C Program\ Turbo ‘C’ 例 见p23 例2-6 aaa
字符串常量 h e l l o \0 例 字符串“hello”在内存中 例 空串 “” \0 例 ‘a’ “a” a a \0 例: char ch; ch=‘A’; • 定义:用双引号(“”)括起来的字符序列 • 存储:每个字符串尾自动加一个 ‘\0’作为字符串结束标志 • 字符常量与字符串常量不同 例: char ch; ch=“A”;
隐式转换 什么情况下发生 运算转换------不同类型数据混合运算时 赋值转换------把一个值赋给与其类型不同的变量时 输出转换------输出时转换成指定的输出格式 函数调用转换------实参与形参类型不一致时转换 运算转换规则:不同类型数据运算时先自动转换成同一类型 6.3不同类型数据间的转换
例1 double float 说明: 高 必定的转换 long 运算对象类型不同时转换 unsigned 例2 int i; float f; double d; long l; int char,short 低 10+‘a’ +i*f - d / l int double double double double int int double double double double double int double double double ch/i + f*d - (f+i) char ch; int i; float f; double d;
一般形式:(类型名)(表达式) 例: (int)(x+y) (int)x+y (double)(3/2) (int)3.6 说明:强制转换得到所需类型的中间变量,原变量类型不变 显式转换(强制转换) 较高类型向较低类型转换时可能发生 例 main() { float x; int i; x=3.6; i=(int)x; printf(“x=%f,i=%d”,x,i); } 结果:x=3.600000,i=3 精度损失问题
6.4 运算符和表达式 算术运算符:(+ - * / % ++ --) 关系运算符:(< <= == > >= !=) 逻辑运算符:((! && ||) 位运算符 :(<< >> ~ | ^ &) 赋值运算符:(= 及其扩展) 条件运算符:(?:) 逗号运算符:(,) 指针运算符:(* &) 求字节数 :(sizeof) 强制类型转换:(类型) 分量运算符:(. ->) 下标运算符:([]) 其它 :(( ) -) C 运 算 符
运算符功能 与运算量关系 要求运算量个数 要求运算量类型 运算符优先级别 结合方向 结果的类型 学习运算符应注意
基本算术运算符: + - * / % 结合方向:从左向右 优先级: - ---->* / % -----> + - (14) (13) (12) 说明: “-”可为单目运算符时,右结合性 两整数相除,结果为整数 %要求两侧均为整型数据 算术运算符和表达式 例 5%2 = -5%2 = 1%10 = 5%1 = 5.5%2 1 2 例 5/2 = -5/2.0 = -1 -2.5 1 0 ()
d1=a+b*c-b/a+b%c*a; /* 复杂表达式1 */ d2=(a+b)*c-(b/a)+(b%c)*a; /* 复杂表达式2 */ d3=a/b; d4=c%b; printf("d1=%d, d2=%d, d3=%d, d4=%d\n", d1,d2,d3,d4); x=3.2; y=2.4; z1=x+y/x-y; /* 复杂表达式3 */ z2=(x+y)/(x-y); /* 复杂表达式4 */ z3=y/b; printf("z1=%f, z2=%f, z3=%f\n",z1,z2,z3); } 例: 阅读下面的程序,了解由算术运算符组成的表达式。 /*example6_8.c */ #include<stdio.h> main() { int a,b,c,d1,d2,d3,d4; double x,y,z1,z2,z3; a=8; b=3; c=10; 程序运行结果: d1=62, d2=134, d3=2, d4=1 z1=1.550000, z2=7.000000, z3=0.800000
作用:使变量值加1或减1 种类: 前置 ++i, --i (先执行i+1或i-1,再使用i值) 后置 i++,i-- (先使用i值,再执行i+1或i-1) 自增、自减运算符++ -- 例 j=3; k=++j; j=3; k=j++; j=3; printf(“%d”,++j); j=3; printf(“%d”,j++); a=3;b=5;c=(++a)*b; a=3;b=5;c=(a++)*b; //k=4,j=4 //k=3,j=4 //4 //3 //c=20,a=4 //c=15,a=4
自增、自减运算符++ -- 例 j+++k; (j++)+k; • 说明: • ++ -- 不能用于常量和表达式,如5++,(a+b)++ • ++ --结合方向: 自右向左 • 优先级:- ++ -- ------>* / % ----->+ - • (14) (13) (12) • 例 -i++ -(i++) • i=3; printf(“%d”,-i++); //-3 • 例 -i++ • i=3; printf(“%d”,-i++);
例: 阅读下面的程序,了解由++和--组成的表达式。 /*example6_11.c */ #include<stdio.h> main() { int a ; double x ; a=16; x =12.6; printf(“a1=%d,a2=%d,a3=%d\n”,a++,a++,a++); • printf(“a1=%d,a2=%d,a3=%d\n”, ++a, ++a, ++a); • printf(“x1=%f,x2=%f,x3=%f\n”,x--,x--,x--); • printf(“x1=%f,x2=%f,x3=%f\n”, --x, --x, --x); • }
简单赋值运算符 符号: = 格式: 变量标识符=表达式 作用:将一个数据(常量或表达式)赋给一个变量 赋值运算符和表达式 a+=3 a=a+3 x*=y+8 x=x*(y+8) x%=3 x=x%3 例 a=3; d=func(); c=d+2; • 复合赋值运算符 • 种类:+= -= *= /= %= 《= 》= &= ^= |= • 含义: exp1 op= exp2exp1 = exp1 op exp2
结合方向:自右向左 优先级: 2 左侧必须是变量,不能是常量或表达式 说明(1): • 赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型 • 例 3=x-2*y; • a+b=3; • 例float f; • int i; • i=10; • f=i; • 则f=10.0 • 赋值表达式的值与变量值相等,且可嵌套 例 int i; i=2.56; //结果i=2; 例: a=b=c=5 a=(b=5) a=5+(c=6) a=(b=4)+(c=6) a=(b=10)/(c=2) //表达式值为5,a,b,c值为5 // b=5;a=5 //表达式值11,c=6,a=11 //表达式值10,a=10,b=4,c=6 //表达式值5,a=5,b=10,c=2
例: a=12; a+=a-=a*a //a=-264 等价于a=a+(a=a-(a*a)) 例: int a=2; a%=4-1; a+=a*=a+=a*=3; //a=288 等价于a=a+(a=a*(a=a+(a=a*3)))
形式:表达式1,表达式2,……表达式n 结合性:从左向右 优先级: 1 逗号表达式的值:等于表达式n的值 用途:常用于循环for语句中 逗号运算符和表达式 //a=15,表达式值60 • 例 a=3*5,a*4 • a=3*5,a*4,a+5 • 例 x=(a=3,6*3) • x=a=3,6*a • 例 a=1;b=2;c=3; • printf(“%d,%d,%d”,a,b,c); • printf(“%d,%d,%d”,(a,b,c),b,c); //a=15,表达式值20 //赋值表达式,表达式值18,x=18 //逗号表达式,表达式值18,x=3 //1,2,3 //3,2,3
关系运算符 种类:< <= == >= > != 结合方向:自左向右 优先级别: 关系运算符和表达式 < <= > >= == != 优先级10(高) 优先级9(低) • 例 c>a+b //c>(a+b) • a>b!=c //(a>b)!=c • a==b<c //a==(b<c) • a=b>c //a=(b>c) • 关系表达式的值:是逻辑值“真”或“假”,用1和0表示 • 例 int a=3,b=2,c=1,d,f; • a>b • (a>b)==c • b+c<a • d=a>b • f=a>b>c //表达式值1 //表达式值1 //表达式值0 //d=1 //f=0
关系运算注意 例 应避免对实数作相等或不等的判断 如 1.0/3.0*3.0==1.0 结果为 可改写为:fabs(1.0/3.0*3.0-1.0)<1e-6 0 例 注意区分“=”与“==” int a=0,b=1; if(a=b) printf(“a equal to b”); else printf(“a not equal to b”);
逻辑运算符和表达式(1) 逻辑运算符 种类: ! && || 逻辑运算真值表 a b !a !b a&&b a||b 真 真 假 假 真 真 真 假 假 真 假 真 假 真 真 假 假 真 假 假 真 真 假 假 • C语言中,运算量:0表示“假”, • 非0表示“真”, • 运算结果: 0表示“假”, • 1表示“真”,
逻辑运算符和表达式(2) ! :从右向左 && :从左向右 || :从左向右 ! (14) && (5) || (4) 高 低 • 优先级: • 结合方向: • 例 a<=x && x<=b • a>b&&x>y • a==b||x==y • !a||a>b // (a<=x) && (x<=b) //(a>b)&&(x>y) //(a==b)||(x==y) //(!a)||(a>b)
逻辑运算符和表达式(4) • 短路特性:逻辑表达式求解时,并非所有的逻辑运算符都被执行,只是在必须执行下一个逻辑运算符才能求出表达式的解时,才执行该运算符 • 例 a&&b&&c //只在a为真时,才判别b的值; • 只在a、b都为真时,才判别 c的值 • 例 a||b||c //只在a为假时,才判别b的值; • 只在a、b都为假时,才判别 c的值 • 例 a=1;b=2;c=3;d=4;m=1;n=1; • (m=a>b)&&(n=c>d) //结果m=0,n=1 < >
非0 =0 expr1 例 if (a>b) printf(“%d”,a); else printf(“%d”,b); printf(“%d”,a>b?a:b); 取expr2值 取expr3值 条件运算符与表达式 • 一般形式: expr1 ? expr2 : expr3 • 执行过程 • 功能:相当于条件语句,但不能取代一般if语句 例 求 a+|b| printf(“a+|b|=%d\n”,b>0?a+b:a-b); • 条件运算符可嵌套 • 如 x>0?1:(x<0?-1:0) • 优先级: 3 例 (a==b)?’Y’:’N’ (x%2==1)?1:0 (x>=0)?x:-x (c>=‘a’ && c<=‘z’)?c-’a’+’A’:c • 结合方向:自右向左 • 如 a>b?a:c>d?c:d a>b?a:(c>d?c:d) • expr1、expr2、expr3类型可不同,表达式值取较高的类型 例 x?‘a’:‘b’ //x=0,表达式值为‘b’; x‡0,表达式值为‘a’ x>y?1:1.5 //x>y ,值为1.0; x<y ,值为1.5
阅读下面的程序,了解三目运算符组成的表达式计算规则。阅读下面的程序,了解三目运算符组成的表达式计算规则。 /*example6_15.c 了解三目运算符的语法规则*/ #include <stdio.h> #include <stdlib.h> main() { int a=3,b=5,c; c=(a>b)?(a+b):(a-b); printf("The max value of a and b is: %d\n",c); a=6; b=2; c=(a>b)?(a-b):(a+b); printf("The max value of a and b is: %d\n",c); }
复杂表达式的计算顺序 C语言共有各类运算符47个,按优先级可分为11个类别共15个优先级。 运算符的优先级与运算方向:P34表2-10
例 阅读程序,分析复杂表达式的计算顺序。 /*example6_18.c 复杂表达式的计算顺序*/ #include <stdio.h> main() { int a=10,b=15,c=14,temp; temp= a+6>b && b-c>c; /* ① */ printf("a+6>b && b-c>c= %d\n",temp); temp=!a+b*c-b/a && b-a*!(c-a); /* ② */ printf("!a+b*c-b/a && b-a*!(c-a)= %d\n",temp); } 请分析并修改程序。
C语言的基本语句结构 • C语言的语句可分为四大类: • 1.表达式语句 • 2.复合语句 • 3.控制语句 • 4.转向控制语句
1.表达式语句 • 一个独立的语句就是表达式语句。 • 如: • a=3*b-c/2; • i--; • ++j: • b=(a>3)? 1:0; • 2.复合语句 • 由一对花括号“{ }”将多个表达式语句括起来所组成。 • 如: • { • a=b+c; • x=y%a; • prinft("a=%d, x=%d\n", a, x); • }
3.控制语句 • 由控制结构组成的语句,有5种控制语句: • (1)选择(分支)语句:if…else。 • (2)多分支语句:switch。 • (3)for循环语句:for。 • (4)while循环:while。 • (5)do_while循环:do…while。 • 4.转向控制语句 • 由系统提供的关键字构成,用于改变程序的流程。 • 有4种转向控制语句: • (1)break;可用于switch语句和循环的语句。 • (2)continue;只适用于循环语句。 • (3)return;用在函数的结束处。 • (4)goto<标号>;可用于程序的任何地方,但不提倡使用。
6.5 标准输入输出函数 常用的标准输入/输出函数有如下几种。 (1)格式化输入/输出函数:scanf()/printf()。 (2)字符输入/输出函数:getc()/putc()。 (3)字符输入/输出函数:getch()/putch()。 (4)字符输入/输出函数:getchar()/putchar()。 (5)字符串输入/输出函数:gets()/puts()。 • C语言无I/O语句,I/O操作由函数实现 • #include <stdio.h> 不同的函数在功能上有所不同,使用时应根据具体的要求,选择合适的输入/输出函数。 • Stdout 表示屏幕,Stdin表示键盘