




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、第三章l 主要内容3.1 C的数据类型的数据类型3.2 常量与变量常量与变量3.3 整型数据整型数据3.4 浮点型数据运行浮点型数据运行3.5 字符型数据字符型数据3.6 变量赋初值变量赋初值 3.7 各类数值型数据间各类数值型数据间的混合运算的混合运算 3.8 算术运算符和算术表达式算术运算符和算术表达式 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 3.10 逗号运算符和逗号表达式逗号运算符和逗号表达式 3.1 C的数据类型C语言提供了以下一些数据类型。 3.2 常量与变量3.2.1 常量和符号常量常量和符号常量在程序运行过程中,其值不能被改变的量称为常量常量区分为不同的类型:整型
2、 100,125,-100,0实型 3.14 , 0.125,-3.789字符型 a, b,2字符串 a, ab,1232例3.1 符号常量的使用#define PRICE 30#include void main ( ) int num, total; num=10; total=num * PRICE; printf(total=%dn,total); 用一个标识符代表一个常量。符号常量的值在其作用域内不能改变,也不能再被赋值。 运行结果:运行结果: total=300total=300 程序中用#define命令行定义PRICE代表常量30,此后凡在本文件中出现的PRICE都代表30,可
3、以和常量一样进行运算如再用赋值语句给PRICE赋值是错的 PRICE=40;/* 错误,不能给符号常量赋值 3.2 常量与变量3.2.2变量变量 变量代表内存中具有特定属性的一个存储单元,它用来存放数据,这就是变量的值,在程序运行期间,这些值是可以改变的。 变量名实际上是一个以一个名字对应代表一个地址,在对程序编译连接时由编译系统给每一个变量名分配对应的内存地址。从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据。 3.2 常量与变量变量命名的规定:语言规定标识符只能由字字母、数字和下划线母、数字和下划线三种字符组成,且第一个字第一个字符必须为字母或下划线符必须为字母或
4、下划线。 例:例:sum,_total, month, Student_name, lotus_1_2_,BASIC, li_ling M.D.John, ¥123,3D64,ab 3.2 常量与变量 编译系统将大写字母和小写字母认为是两个不同的字符。 建议变量名的长度最好不要超过8个字符。 在选择变量名和其它标识符时,应注意做到“见名知意”,即选有含意的英文单词 (或其缩写)作标识符。 要求对所有用到的变量作强制定义,也就是“先定义,后使用先定义,后使用” 。 3.3 整型数据3.3.1整型常量的表示方法整型常量的表示方法 整型常量即整常数。在语言中,整常数可用以下三种形式表示:(1)十进制
5、整数。 如:如:123, -4564。(2)八进制整数。以0头的数是八进制数。 如:如:0123表示八进制数123,等于十进制数83,-011表示八进制数-11,即十进制数-9。 3.3 整型数据(3)十六进制整数。以0 x开头的数是16进制数。 如:如:0 x123,代表16进制数123,等于十进制数 291。 -0 x12等于十进制数10。 3.3.2 整型变量整型变量 (1)(1)整型数据在内存中的存放形式整型数据在内存中的存放形式 数据在内存中是以二进制形式存放的。 如如: : int i; /* 定义为整型变量 */ i=10; /* 给i赋以整数10 */ 0000000 1010
6、这里有这里有12个个0总共总共32位,即位,即4字节字节 3.3 整型数据(2)(2)整型变量的分类整型变量的分类共六种共六种有符号基本整型有符号短整型有符号长整型无符号基本整型无符号短整型无符号长整型(signed)int 4B/2B(signed)short (int ) 2B(signed) long (int) 4Bunsigned int 4B/2Bunsigned short (int) 2Bunsigned long (int) 4B 注意:注意:括号表示其中的内容是可选的. 3.3 整型数据 整数类型的有关数据: 原因:数值是以补码数值是以补码(complement) (com
7、plement) 表示的。表示的。 补充一:计算机内存知识计算机的所有程序运行都需要加载到内存中运行,内存,从物理结构上看,如图:由于计算机是以字节为单位访问内存的,因此内存空间逻辑上被划分:1Byte8bit补充一:计算机内存知识换个角度看内存:逻辑上,内存被分成“一间间房子”,每个房子的“面积”为1个字节(Byte)。.问题问题1:计算机怎么知道自己:计算机怎么知道自己访问的是访问的是“哪间房子哪间房子”呢?呢?1234nn-1n-2n-3答案:为每间房子进行编号,这个编号就叫做“地址”。问题问题2:总共有多少间:总共有多少间“房子房子”呢?呢?答案:取决于内存的大小,假设内存为4GB,那
8、么总共有:4 * 1024 * 1024 * 1024 = 232 间房子。补充二:数据在计算机中的存放 复习一:信息在计算机中是以二进制存放的,例如十进制数10,在计算机中为1010B。 复习二:内存以1个字节为单位,被分成“N间房子”,字节是计算机访问内存的基本单位。1Byte = 8Bit 问题:一个字节最多能存放多大的数呢,多少个数呢?1/01/01/01位最大为:1总共0-1,2个数2位最大为3,总共0-3,4个数1/01/01/01/04位最大为15,总共0-15,16个数21-122-124-18位最大为28-1,255,总共0-255,256(28 )个数212224补充二:数
9、据在计算机中的存放 拓展:在考虑符号的情况下 问题1:有符号位的情况下,5位能表示多大的数呢?5-50101010101原码符号位符号位符号位符号位在没有符号位的情况下,能表示的最大的数为 : 25-1增加了符号位后,能表示的最大的数为 : 24-1 难题:有符号位的情况下,5位能表示多小的数呢?11111符号位符号位00001符号位符号位不对,这个实际上是不对,这个实际上是-1最小的数为-24补充二:数据在计算机中的存放 思考:原码带来的问题0101010101请问这都代表的是什么十进制数?22 + 20 = 4 + 1 = 5 22 + 20 = 4 + 1 = 5 由于符号位为由于符号位
10、为1,所以为,所以为-5由于符号位为由于符号位为0,所以为,所以为5问题1: 多于的判断操作这个多于的操作会造成效率低下,我们希望符号位统一参与运算,去掉判断:-1* 0 * 24 + 22 + 20 = 4 + 1 = 5 -1* 1 * 24 + 22 + 20 ,希望等于-5 问题2:理论上5 + (-5) = 00101001011+10101 00000001010-10111-5的正确表示的正确表示希望结果为0,应该怎么办?-1 * 24 + 23 + 21 + 20= -16 + 8 + 2 + 1 = -5补充二:数据在计算机中的存放由于该2进制表示,是为了凑0(补0)而变出来
11、的,所以,叫做补码补码补充二:数据在计算机中的存放在计算机中,为了统一计算并解决正数+负数=0的问题,数都是以补码进行表示的: 补码正数的补码正数的补码 = 正数的原码正数的原码+5的原码/补码01010负数的补码负数的补码 = 负数的原码负数的原码 取反(符号位不取反(符号位不变)变) + 1-5的原码0101110101取反取反10111+1-5的补码补充二:数据在计算机中的存放 解决疑问:在考虑符号的情况下,数的表示范围(以5位为例)1111100001这个实际上是这个实际上是-1的补码的补码-2411110正数最大24-1:负数最小:因此,以5位为例的情况下,数的表示范围为: 24-1
12、-24 思考:为什么正数比负数少表示1个数00000/1原因在于0:当5为n的时候,数的表示范围为:2n-1-1-2n-1练习:请写出下面数的原码和补码(以2字节为单位)13, -24, 256, -259, -1, -192, -8, 19 3.3 整型数据(3)(3)整型变量的定义整型变量的定义: : 规定在程序中所有用到的变量都必须在程序中定义(实际上就是告诉计算机,占用多大内存),即“强制类型定义”。 例如例如: : int a,bint a,b(指定变量、为整型) unsigned short c,d;unsigned short c,d;(指定变量、为无符号短整型) long e,
13、f;long e,f;(指定变量、为长整型)例3.2 整型变量的定义与使用#include void main() int a,b,c,d; /*指定、为整型变量* unsigned ; *指定为无符号整型变量* 12;-24;10; ; printf(,); 可以看到不同种类的整型数据可以进行算术运算 运行结果:运行结果: , 例3.3 整型数据的溢出#include void main()short a,b; a=32767; b=a+1; printf(“%d,%dn”,a,b);数值是以补码表示的。一个整型变量只能容纳-3276832767范围内的数,无法表示大于32767或小于-32
14、768的数。遇此情况就发生“溢出”。运行结果:运行结果: 32767,-3276832767,-327680111 1110000 001+1000 0003.3 整型数据3.3.3 整型常量的类型整型常量的类型(1)一个整数,如果其值在-32768+32767范围内,认为它是int(short)型,它可以赋值给int(short)型和long int型变量(2) 一个整数,如果其值超过了上述范围,而在-2147483637+2147483647范围内,则认为它是为长整型。可以将它赋值给一个long int(int)型变量。(3) 如果所用的C版本(如Turbo C)分配给short int与
15、int型数据在内存中占据的长度相同,则它的表数范围与int型相同。因此一个int型的常量同时也是一个short int型常量,可以赋给int型或short int型变量。 3.3 整型数据(4) 一个整常量后面加一个字母u或U,认为是unsigned int型,如12345u,在内存中按unsigned int规定的方式存放(存储单元中最高位不作为符号位,而用来存储数据)。如果写成-12345u,则先将-12345转换成其补码53191,然后按无符号数存储。(5) 在一个整常量后面加一个字母l或L,则认为是long int型常量。 例如: 123l,432L,0L 3.4 浮点型数据3.4.1
16、3.4.1浮点型常量的表示方法浮点型常量的表示方法两种表两种表示形式示形式小数小数指数指数0.1230.1233 3e-3e-3注意注意: :字母e(或E)之前必须有数字,且e后面的指数必须为整数 3.4 浮点型数据规范化的指数形式:规范化的指数形式: 在字母e(或E)之前的小数部分中,小数点左边应有一位(且只能有一位)非零的数字. 例如例如: : 123.456可以表示为: 123.456e0, 12.3456e1, 1.23456e2, 0.123456e3, 0.0123456e4, 0.00123456e 其中的1.23456e31.23456e3称为“规范化的指数形式”。3.4 浮点
17、型数据3.4.2 浮点型变量浮点型变量(1)(1)浮点型数据在内存中的存放形式浮点型数据在内存中的存放形式 一个浮点型数据一般在内存中占4个字节(32位)。与整型数据的存储方式不同与整型数据的存储方式不同:浮点型数据是按照指数形式存储的。系统把一个浮点型数据分成小数部分和指数部分小数部分和指数部分,分别存放。指数部分采用规范化的指数形式。例3.4 浮点型数据的舍入误差#include void main()float a,b; a = 123456.789e5; b = a + 20 ; printf(“%fn”,b);一个浮点型变量只能保证的有效数字是7位有效数字,后面的数字是无意义的,并不
18、准确地表示该数。应当避免将一个很大的数和一个很小的数直接相加或相减,否则就会“丢失”小的数运行结果:运行结果: 123456.789e5123456.789e5 3.4 浮点型数据3.4.3 浮点型常量的类型浮点型常量的类型 C编译系统将浮点型常量作为双精度来处理。 例如例如:f = 2.45678 * 4523.65 系统先把2.45678和4523.65作为双精度数,然后进行相乘的运算,得到的乘也是一个双精度数。最后取其前7位赋给浮点型变量f。如是在数的后面加字母f或F(如1.65f, 654.87F),这样编译系统就会把它们按单精度(32位)处理。 作业:1、请分别定义1个整形变量,1个
19、短整型变量,1个无符号整形变量,1个无符号短整型变量,1个单精度浮点变量,1个双精度浮点变量。(数值自取)2、现假设int和unsigned int 都只占用1个字节,请问下题的结果:int i = 255;int b = i + 1;unsigned i = 511;unsigned b = i + 1;3、思考题:假设int和unsigned int 都只占用1个字节int i = 255;unsigned int b = 1;请问i+b的值是什么,为什么?4、请问1/3存放在float和double型中的实际值分别是什么,假设float a和double b都存放了1/3的值,如何判断a
20、和b相等。 3.5 字符型数据 3.5.1 字符常量字符常量(1)用单引号包含的一个字符是字符型常量(2)只能包含一个字符a a, ,A A, , 1 1abcabc、“a a”例如:(3)有些以有些以“ ”开头的特殊字符称为转义字符开头的特殊字符称为转义字符 n 换行 t 横向跳格,跳到tab制表符整数 r 回车(回到行首) 反斜杠 ddd ddd表示1到3位八进制数字 xhh hh表示1到2位十六进制数字例3.5 转义字符的使用#include void main() printf( ab ct derftgn);printf(htibbj kn); 打印机上的显示结果:打印机上的显示结果
21、: fab c gde h jik 显示屏上的运行结果:显示屏上的运行结果: f gde j k 3.5 字符型数据 3.5.2字符变量字符变量 字符型变量用来存放字符常量,注意只能放一个字符。 字符变量的定义形式如下:char c1,c2; 在本函数中可以用下面语句对c1,c2赋值: c1a;c2 b ; 一个字符变量在内存中占一个字节。 3.5 字符型数据 3.5.3 字符数据在内存中的存储形式及其使用方法字符数据在内存中的存储形式及其使用方法 一个字符常量存放到一个字符变量中,实际上并不是把该字符的字型放到内存中去,而是将该字符的相应的ASCII代码放到存储单元中。这样使字符型数据和整型
22、数据之间可以通用。注意: 一个字符数据既可以以字符形式输出,也可以以整数形式输出。例3.6 向字符变量赋以整数。#include void main() char c1,c2; c1=97; c2=98; printf(“%c %cn”,c1,c2); printf(“%d %dn”,c1,c2); 在第和第4行中,将整数97和98分别赋给c1和c2,它的作用相当于以下两个赋值语句: c1;c2; 因为a和b的ASCII码为97和98 运行结果:运行结果: 97 98 97 98例3.7 大小写字母的转换#include void main() char c1,c2; c1=a; c2=b;c
23、1=c1-32;c2=c2-32; printf(“c c,c1,c2); 程序的作用是将两个小写字母a和b转换成大写字母A和B。从代码表中可以看到每一个小写字母比它相应的大写字母的ASCII码大32。语言允许字符数据与整数直接进行算术运算。 运行结果:运行结果: 3.5 字符型数据 有些系统(如Turbo C)将字符变量定义为signed char型。其存储单元中的最高位作为符号位,它的取值范围是-128127。如果在字符变量中存放一个ASCII码为0127间的字符,由于字节中最高位为0,因此用%d输出字符变量时,输出的是一个正整数。如果在字符变量中存放一个ASCII码为128255间的字符
24、,由于在字节中最高位为1,用%d格式符输出时,就会得到一个负整数。 3.5 字符型数据3.5.4字符串常量字符串常量 字符串常量是一对双撇号括起来的字符序列. 合法的字符串常量:“How do you do.”, “CHINA”, “a” , “$123.45” 可以输出一个字符串,如printf(“How do you do.”); 3.5 字符型数据 是字符常量,”是字符串常量,二者不同。 如:如:假设被指定为字符变量 :char cc=a; ”a”;c”CHINA”; 结论:结论:不能把一个字符串常量赋给一个字符变量。 规定:在每一个字符串常量的结尾加一个 “字符串结束标志”,以便系统据
25、此判断字符串是否结束。 规定以字符作为字符串结束标志。 如:如:如果有一个字符串常量” ,实际上在内存中是:CHINA0它占内存单元不是个字符,而是个字符,最后一个字符为。但在输出时不输出。 3.5 字符型数据 3.6 变量赋初值(申明和定义的区别) (1)要在计算机中存放数据,就必须告诉计算机数据所需内存大小,这个过程通过变量申明变量申明来实现:如如: : int a;int a; / 指定为整型变量 float f;float f; / 指定为浮点型变量 char c;char c; / 指定为字符变量afc注:这里只是占用了内存空间,里面并没有数据,或者只有内存的原始数据(raw dat
26、a)。(2)语言允许在定义变量的同时使变量初始化(即为变量赋值,或叫变量定义变量定义)int a=3;float f = 3.56; char c = a;这里面保存了具体的数值 3.6 变量赋初值 (3)可以使被定义的变量的一部分赋初值。 如如: : int a,b,c=5; 表示指定、为整型变量,但只对初始化,c的初值为(4)如果对几个变量赋以同一个初值,应写成: int a=3,b=3,c=3; 不能写成 int a=b=c=3; 注意:注意:初始化不是在编译阶段完成的而是在程序运行时执行本函数时赋初值的,相当于有一个赋值语句。 3.7 各类数值型数据间的混合运算 混合运算:整型(包括i
27、nt,short,long)、浮点型(包括float,double)可以混合运算。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算.说明: 这种类型转换是由系统自动进行的。可以认为是可以认为是从小到大从小到大3.7 各类数值型数据间的混合运算 int a = 3; float b = 3.25f; double c = 1.0; char d = a;例:int a1 = d;float b1 = a;double c1 = d;double c2 = a1 + a + d;float b2 = a1 + d;float b2 = a1 + d / 3;思考:int a2 = b;
28、int a3 = a + b;char d2 = c;9797.0 + 97.097.0 + 97.0/397.0 + 3.0 + 97.097.03.03ASCII码1代表的字符3.0 + 3.25 = 6.25 最后结果为6 3.8 术运算符和算术表达式3.8.1 运算符简介运算符简介的运算符有以下几类:的运算符有以下几类:(1)算术运算符 (+ - * / %)(2)关系运算符 (!)(3)逻辑运算符 (!|)(4)位运算符 ( |)(5)赋值运算符 (及其扩展赋值运算符)(6)条件运算符 (?:)(7)逗号运算符 (,) 3.8 算术运算符和算术表达式(8)指针运算符 (*和)(9)求
29、字节数运算符()(10)强制类型转换运算符( (类型) )(11)分量运算符(-)(12)下标运算符()(13)其他 (如函数调用运算符() 3.8 算术运算符和算术表达式3.8.2 算术运算符和算术表达式算术运算符和算术表达式 (1)(1)基本的算术运算符基本的算术运算符: : (加法运算符,或正值运算符。如:、) (减法运算符,或负值运算符。如:、)* * (乘法运算符。如:*) (除法运算符。如:) (模运算符,或称求余运算符,两侧均应为整型数据,如:的值为)。注:C语言的变量、常量、函数等可以和运算符混合使用例如例如: : *.5a 是一个合法的表达式 语言规定了运算符的优先级和结合性
30、。 在表达式求值时,先按运算符的优先级别高低次序执行,例如先乘除后加减。 规定了各种运算符的结合方向(结合性) 算术运算符的结合方向为“自左至右”,即先左后右 3.8 算术运算符和算术表达式a+b-c;例:a+b*d-c/3; 3.8 算术运算符和算术表达式( (2 2) ) 自增、自减运算符自增、自减运算符作用是使变量的值增或减,如如: ,i, , i+i+与与+i+i的区别:的区别:是先执行后,再使用的值( (前缀表达式)前缀表达式)是先使用的值后,再执行( (后缀表达式后缀表达式) )例如:例如:int i = 3;int i = 3; ; i的值先变成4, 再赋给,j的值均为 ; 先将
31、 i的值3赋给,的值为,然后变为 3.8 算术运算符和算术表达式注意:注意: (1)自增运算符(),自减运算符(),只能用于变量,而不能用于常量或表达式, (2)和的结合方向是“自右至左”。提示:自增(减)运算符常用于循环语句中使循环变量自动加。也用于指针变量,使指针指向下一个地址例:int i = 3, j =4; -i+; i+j;推荐写法: -(i+); (i+)+j; 3.8 算术运算符和算术表达式 语言中有的运算符为一个字符,有的运算符由两个字符组成 ,为避免误解,最好采取大家都能理解的写法。 例如:不要写成i+j的形式,而应写成(i+)+j的形式 ANSI C并没有具体规定表达式中
32、的子表达式的求值顺序,允许各编译系统自己安排。 例如:对表达式 a = f1( )+f2( ) 并不是所有的编译系统都先调用f1( ), 然后调用f2( )。在有的情况下结果可能不同。有时会出现一些令人容易搞混的问题,因此务必要小心谨慎。( (3 3) ) 难点:难点:有关表达式使用中的问题说明有关表达式使用中的问题说明3.8 算术运算符和算术表达式在调用函数时,实参数的求值顺序,标准并无统一规定。例如:例如:的初值为,如果有下面的函数调用: printf(,i+) 在有的系统中,从左至右求值,输出“,”。在多数系统中对函数参数的求值顺序是自右而左,printf函数输出的是“,”。以上这种写法
33、不宜提倡, 最好改写成 j = i+; j = i+; printf(%d printf(%d, %d %d, j j,i)i)总结:总结:不要写出别人看不不要写出别人看不懂的也不知道系统会怎样懂的也不知道系统会怎样执行程序执行程序 3.9 赋值运算符和赋值表达式 (1)(1)赋值运算符赋值运算符赋值符号“”就是赋值运算符,它的作用是将一个数据赋给一个变量。如“”的作用是执行一次赋值操作(或称赋值运算)。把常量赋给变量。也可以将一个表达式的值赋给一个变量. 难点:赋值运算符与难点:赋值运算符与类型转换类型转换 如果赋值运算符两侧的类型不一致,但都是数值型或字符型时,在赋值时要进行类型转换( (
34、自动的)自动的)。3.9 赋值运算符和赋值表达式 将浮点型数据(包括单、双精度)赋给整型变量时,舍弃浮将浮点型数据(包括单、双精度)赋给整型变量时,舍弃浮点数的小数部分。点数的小数部分。 难点:赋值运算符与难点:赋值运算符与类型转换类型转换例:例: int i = 3.14f; 将整型数据赋给单、双精度变量时,数值不变,但以浮点将整型数据赋给单、双精度变量时,数值不变,但以浮点数形式存储到变量中数形式存储到变量中printf(“%d”, i) 输出为3如如: : float f 23,先将23转换成23.000000,再存储在中。 double23, 系统将23补足有效位数字为23.0(15个
35、),然后以双精度浮点数形式存储到变量中。 3.9 赋值运算符和赋值表达式 将一个double型数据赋给float变量时,截取其前面6位有效数字,但应注意数值范围不能溢出但应注意数值范围不能溢出。 如如: : double b = 3.1234567891234;double b = 3.1234567891234; float c = b; /c float c = b; /c的值为的值为3.1234563.123456字符型数据赋给整型变量时,由于字符只占1个字节,而整型变量为个字节,因此将字符数据(个二进位)放到整型变量存储单元的低位中。而高8位的情况分为两种:第一种情况:低位对应、高位补
36、零低位对应、高位补零 若所用系统将字符处理为无符号字符类型,或程序已将字符变量定义为unsigned char型,则将字符的位放到整型变量低位,高位补零。例如:例如:将字符将字符376赋给赋给int型变量型变量第二种情况:符号扩展符号扩展 若所用系统将字符处理为带符号(signed char)时,若字符最高位为,则整型变量高位补;若字符最高位为,则高位全补。这称为“符号扩展”,这样做的目的是使数值保持不变,如变量(字符376)以整数形式输出为,的值也是。拓展:符号扩展的数学基础补码的特点:依然考虑-5这个数,并假设目前有一个字节有5位:10111-5-1 * 24 + 23 + 21 + 20
37、= -16 + 8 + 2 + 1 = -5现在假设一个字节有6位:10111-51-1 *25 + 24 + 23 + 21 + 20= -32 + 16 + 8 + 2 + 1 = -5符号扩展的理论基础为:对于补码存放的有符号数,在高位补1(负数)或0(正数),不影响数值的大小。以此类推,可以到N位u 提示:第四点可以扩展为提示:第四点可以扩展为占用空间小的带符号数占用空间小的带符号数据变量赋值给据变量赋值给占用空占用空间大的间大的带符号数据变量的时候。带符号数据变量的时候。 3.9 赋值运算符和赋值表达式 将一个int、short、long型数据赋给一个char型变量时,只将其低8位原
38、封不动地送到char型变量(即截断)。 例如:例如:int i=289;char c=a;c=i;c的值为33,如果用“%c”输出c,将得到字符“!”赋值情况赋值情况 : 这一点可以扩展为:把一个占用空间大的数据变量占用空间大的数据变量a赋值给一个占用空间小占用空间小b的变量的变量时,仅从a的低位开始截取b的空间大小的数据。3.9 赋值运算符和赋值表达式 例: 现假设short为4位,int为1个字节,计算以下数据int a = -1;short b = a;int a = 18;short b = a;int a = 127;short b = a;11111111a:1111b:00010
39、010a:0010b:01111111a:b:1111b=-1b=2b=-1思考:如果b的类型为unsigned short呢? 3.9 赋值运算符和赋值表达式 无论是截断还是符号扩展,数据的解释方式取决于被赋值的变量类型本身。而对于无符号变量,当其赋值给一个有符号变量时,不考虑符号扩展。例:unsigned short a = 65535;int b = a;printf(“%d”, b)b的值为65535111 111111 11100016个10032位3.9 赋值运算符和赋值表达式 强制转换与赋值运算思考:以下程序的运行结果是什么?void main() int a = 10, b =
40、 15; float c = a/b; printf(“%fn”, c);原因:由于a和b都是int型变量,因此a/b的值也是一个int型数据,即10/15 = 0.6666666,即为0,这时候赋值给c转换,自动转换成float型,所以c为0float c = (float) a / bfloat c = (float) a / (float) b强制类型转换提示:强制类型转换的使用方法 (类型名) 变量名 或 (类型名) 常量 即:float c = (float)10 / 15; 3.9 赋值运算符和赋值表达式 (3) (3) 复合的赋值运算符复合的赋值运算符在赋值符“”之前加上其他运算
41、符,可以构成复合的运算符例如例如: 等价于 * 等价于 *() 等价于 以以“”为例来说为例来说明,它相当于使进行一明,它相当于使进行一次自加()的操作。即次自加()的操作。即先使加,再赋给。先使加,再赋给。提示:为便于记忆,可以这样理解:提示:为便于记忆,可以这样理解: a += b (其中a为变量,b为表达式) a += b(将有下划线的“a+”移到“=”右侧) |_ a = a + b (在“=”左侧补上变量名a) 3.9 赋值运算符和赋值表达式 注意注意: :如果是包含若干项的表达式,则相当于它有如果是包含若干项的表达式,则相当于它有 括号。括号。如:如: x %= y+3 x %=
42、(y+3) |_ x = x %(y+3)(不要错写成x=x%y+3) 凡是二元(二目)运凡是二元(二目)运算符,都可以与赋值算符,都可以与赋值符一起组合成复合赋符一起组合成复合赋值符。值符。 语言规定可以使用种复合赋值运算符:语言规定可以使用种复合赋值运算符:,* *,| | 3.9 赋值运算符和赋值表达式 ( (2 2) ) 赋值表达式赋值表达式 由赋值运算符将一个变量和一个表达式连接起来的式子称为“赋值表达式”。 一般形式为一般形式为: = 例如例如: “5”是一个赋值表达式 对赋值表达式求解的过程是:对赋值表达式求解的过程是: 求赋值运算符右侧的“表达式”的值(称为右值Rvalue)
43、赋给赋值运算符左侧的变量(称为左值, Lvalue)例如例如: 赋值表达式“=3*5”的值为15,执行表达式后,变量的值也是15。 3.9 赋值运算符和赋值表达式 左值左值 (lvalue) (lvalue) : 赋值运算符左侧的标识符变量可以作为左值;而表达式就不能作为左值(如a+b);常变量也不能作为左值 右值右值 (lvalue) (lvalue) :出现在赋值运算符右侧的表达式 左值也可以出现在赋值运算符右侧,因而左值 都可以作为右值。 3.9 赋值运算符和赋值表达式 赋值表达式中的“表达式”,又可以是一个赋值表达式。 例如例如: : a=(b=5) 分析分析: :括弧内的“b=5”是
44、一个赋值表达式,它的值等于5。执行表达式“a=(b=5)”相当于执行“b=5”和“ab”两个赋值表达式。 赋值运算符按照“自右而左”的结合顺序,因此,“(b5)”外面的括弧可以不要,即“a=(b=5)”和“a=b=5”等价。 3.9 赋值运算符和赋值表达式 请分析下面的赋值表达式(a=3*5)=4*3分析分析: :先执行括弧内的运算,将15赋给a,然后执行4*3的运算,得12,再把12赋给a。最后a的值为12,整个表达式的值为12。可以看到(a=3*5)出现在赋值运算符的左侧,因此赋值表达式(a=3*5)是左值 注意注意: :在对赋值表达式(a=3*5)求解后,变量a得到值15执行(a=3*5
45、)=4*3时,实际上是将4*3的积12赋给变量a,而不是赋给3*5。不能写成:a=3*5=4*3 3.9 赋值运算符和赋值表达式 赋值表达式也可以包含复合的赋值运算符。 如:如:a+=a-=a*a分析分析: :此赋值表达式的求解步骤如下 先进行“*”的运算, 它相当于*,a的值为144132。再进行“”的运算,相当于=a+(-132),a的值为132-132-264。 3.9 赋值运算符和赋值表达式 将赋值表达式作为表达式的一种,使赋值操作不仅可将赋值表达式作为表达式的一种,使赋值操作不仅可以出现在赋值语句中,而且可以以表达式形式出现在以出现在赋值语句中,而且可以以表达式形式出现在其他语句(如
46、输出语句、循环语句等)中。其他语句(如输出语句、循环语句等)中。 如:如:printf(%d,a=b); 分析分析: :如果b的值为3, 则输出a的值(也是表达式a=b的值)为3。在一个语句中完成了赋值和输出双重功能。 3.10 逗号运算符和逗号表达式逗号运算符逗号运算符: :将两个表达式连接起来,又称为“顺序求值运算符” 如:如:5, 一般形式一般形式: : 表达式,表达式表达式,表达式, ,表达式,表达式n求解过程:求解过程: 先求解表达式,再求解表达式。整个逗号表达式的值是表达式的值。 逗号表达式 的值为143.11 格式输入与输出(一)(一). .格式输出函数格式输出函数函数作用:向终
47、端(或系统隐含指定的输出设备)函数作用:向终端(或系统隐含指定的输出设备)输出输出若干个任意类型若干个任意类型的数据。的数据。一般格式:一般格式:printfprintf( (“格式控制格式控制”,输出表列,输出表列););%d%d: :以带符号的十进制形式输出整数以带符号的十进制形式输出整数%o%o: :以八进制无符号形式输出整数以八进制无符号形式输出整数%x%x: :以十六进制无符号形式输出整数以十六进制无符号形式输出整数%u%u: :以无符号十进制形式输出整数以无符号十进制形式输出整数%c%c: :以字符形式输出,只输出一个字符以字符形式输出,只输出一个字符%s%s: :输出字符串输出字
48、符串%f%f: :以小数形式输出单,双精度数,隐含输出六位小数以小数形式输出单,双精度数,隐含输出六位小数%e%e: :以指数形式输出实数以指数形式输出实数%g%g: :选用选用%f%f或或%e%e格式中输出宽度较短的一种格式,不输出无意义的格式中输出宽度较短的一种格式,不输出无意义的0 0格式符。用来输出十进制整数。格式符。用来输出十进制整数。几种用法: d:按十进制整型数据的实际长度输出。 md: m为指定的输出字段的宽度。如果数据的位数小于, 则左端补以空格,若大于,则按实际位数输出。 例: printf(“%d, %d”, a, b); 若a = 123, d=12345, 则输出结果
49、为 123,123456 %ld: 输出长整型数据。 例: long a = 135790 ;/* 定义a为长整型变量*/ printf(“%ld”, a);3.11 格式输入与输出(2) (2) 格式符。以八进制整数形式输出。格式符。以八进制整数形式输出。输出的数值不带符号,符号位也一起作为八进制数的一部分输出。例:int a=-1; printf(%d,%o,a,a); -1在内存单元中的存放形式(以补码形式存放)如下: 11 111 111 111 111 111 111 111 111 111 111 输出为: ,37777777777提示:不会输出带负号的八进制整数。对长整数(型)可
50、以用“”格式输出。还可以指定字段宽度,例:(12,); 输出为: 37777777777 (数字前有1个空格)3.11 格式输入与输出(3)(3)格式符。以十六进制数形式输出整数。格式符。以十六进制数形式输出整数。同样不会出现负的十六进制数。同样不会出现负的十六进制数。例: ; (,); 输出结果为: ffffffff,37777777777,可以用“”输出长整型数,也可以指定输出字段的宽度例: “”3.11 格式输入与输出(4)(4)格式符,用来输出格式符,用来输出unsignedunsigned型数据型数据. .一个有符号整数(int型)也可以用%u格式输出;注意:一个unsigned型数
51、据也可以用%d格式输出。unsigned型数据也可用或格式输出。(5)格式符格式符,用来输出一个字符。如: chard; printf(,d); 输出字符.一个整数,只要它的值在127范围内,可以用“”使之按字符形式输出,在输出前,系统会将该整数作为ASCII码转换成相应的字符;一个字符数据也可以用整数形式输出。 3.11 格式输入与输出例 无符号数据的输出。#includevoid main()unsigned short a=65535;int b=-2;printf(“a=%d,%o,%x,%un”,a,a,a,a);printf(“b=%d,%o,%x,%un”,b,b,b,b); 运
52、行结果:运行结果:a=-1a=-1,177777177777,ffffffff,6553565535b=-2b=-2,177776177776,fffefffe,65534655343.11 格式输入与输出例 字符数据的输出。#includevoid main()char c=a;int i=97;printf(“%c,%dn”,c,c);printf(“%c,%dn”,i,i); 运行结果:运行结果:a,97a,97a,97a,97指定输出字数的宽度,指定输出字数的宽度,printf(printf(“%3c%3c”,c);,c);则输出:则输出: a a3.11 格式输入与输出练习请分别定义
53、2个int变量,计算它们的和、差、积,余数。并且分别按照以下格式输出这些值,商要求保留2位有效数字。a+b = 和a-b = 差a*b = 积a%b = 余数如:int a = 3, b = 4; int c = a + b; printf(“a+b = %d”, c);提示1:可以直接写成 printf(“a+b=%d”, c);提示2:要输出%号的在printf里面应该写成%(6)s(6)s格式符格式符 输出字符串输出字符串. . 。例如: printf(“%s”, “CHINA”) 输出字符串“”(不包括双引号)。 %ms,输出的字符串占m列,若串长大于m,则全部输出,若串 长小于m,则
54、左补空格。 %-ms,若串长小于m,字符串向左靠,右补空格。 %m. ns,输出占m列,只取字符串中左端n个字符,输出在m列的 右侧,左补空格。 %-m.ns,n个字符输出在m列的左侧,右补空格,若nm,m自 动取n值。3.11 格式输入与输出例例 字符串的输出。#includevoid main() printf(“%3s,%7.2s,%.4s,%-5.3sn”, “CHINA”, “CHINA”, “CHINA”, “CHINA”); 运行结果:运行结果:CHINACHINA, CH ,CHIN,CHI CH ,CHIN,CHI 3.11 格式输入与输出(7)(7)格式符。用来以小数形式输
55、出实数(包括单双精度)格式符。用来以小数形式输出实数(包括单双精度)有以下几种用法: 。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为位。.。指定输出的数据共占列,其中有位小数。如果数值长度小于,则左端补空格。.与.基本相同,只是使输出的数值向左端靠,右端补空格。 3.11 格式输入与输出例例 输出实数时的有效位数。#include void () ,;(,);运行结果:运行结果:. .3.11 格式输入与输出例例 输出双精度数时的有效位数。#include void () ,;x=1111111111111.111111111; y=2222222222222.222222222;printf(“%f”,x+y);运行结果:运行结果:3333333333333.3330103333333333333.3330103.11 格式输入与输出例 输出实数时指定小数位数。#include void ()float f=123.456;printf(“%f%10f%10.2f%.2f%-10.2fn”,f,f,f,f,f);运行结果:运行结果:3.11 格式输入与输出(一)(一). .格式输入函数格式输入函数 函数作用:按
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 付费搭建店铺合同范本
- 内墙抹灰施工合同范本
- 农民工工资付款合同范本
- 关于规范使用合同范本
- 办公辅助岗位合同范本
- 住宅消防维修采购合同范本
- mind+ 星球大战 教学设计
- 出售货架合同范本
- 与劳务外包签订合同范本
- 勘探合同属于合同范本
- 患者隐私保护的考试试题及答案
- 2025年中考数学一轮教材复习-第六章 圆 与圆有关的概念及性质
- 运维服务体系建立实施方案(5篇)
- 路面基层(级配碎石)施工方案
- 2025年村两委工作计划
- 2025年日历(日程安排-可直接打印)
- 事业单位考试职业能力倾向测验(社会科学专技类B类)试题及答案指导(2025年)
- 中小学反诈宣传课件
- 口腔执业医师定期考核试题(资料)带答案
- 2024年三八妇女节妇女权益保障法律知识竞赛题库及答案(共260题)
- 北京工业大学《机器学习基础》2022-2023学年期末试卷
评论
0/150
提交评论