欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    第2章 C语言的基本数据类型和存储类&数据类型、运算符与表达式.ppt

    • 资源ID:2674081       资源大小:575KB        全文页数:51页
    • 资源格式: PPT        下载积分:8金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第2章 C语言的基本数据类型和存储类&数据类型、运算符与表达式.ppt

    第2章 C语言的基本数据类型和存储类,2.1 整型数据 2.1.1 整型常量整型常量即整常数,中的整常数可以有三种表示形式,即十进制整数、八进制整数和十六进制整数。整型常量的说明:123L、123U、123LU十进制数:一串连续的数字表示,最高位非零。八进制数:以数字零开头。十六进制数:以数字零和字母x开头,a-f不区分大小写。考虑如下常数:32767,-32768,0,010,011,016,018,ox10,0 xde,0 xf,2.1.2 整型变量,语言中的整型变量分为有符号和无符号两种,所有变量在使用前必须加以说明或定义。其中:每种有符号整型变量又可细分为标准整型(int)、短整型(short)和长整型(long)三类,其值可正可负。例如:int a,b;/short c,d;/long f,g;每种无符号整型变量也可细分为标准整型(unsigned int)、短整型(unsigned short)和长整型(unsigned long)三类,其值不能为负。例如:unsigned int a,b;/unsigned short c,d;/unsigned long f,g;int、short和long的区别主要在表示的整数范围不同。通常以一个机器字来存放一个int型数据。且int、short和long型整数的字长满足:shortintlong,2.1.3 整型数据的存储表示,正整数:以原码形式存放在内存中,字长为16时,整数范围取 0-32767。例如:整数 5 对应 0000000000000101。负整数:以补码形式存放在内存中。例如:-5十进制负整数补码形式:1000000000000101原码求原码的反码:1111111111111010反码把所得的反码加1:1111111111111011补码内存中的补码 十进制负整数:对补码各位取反:1111111111111010补码,取反后得:1000000000000101将其转换为十进制数:得-5将结果减1,得-5-1=-6。考虑1000000000000000、1111111111111111,2.2 字符型数据,2.2.1 字符型常量字符型常量是由一对单引号括起来的单个字符(可打印)。如:x,a,A,b,$,#。一个转义序列是一个反斜线后跟特定的字符,表示某些不可打印的字符(如回车符,响铃符等)。例如:n 换行符 反斜线符 t 水平制表符 单引号符 b 退格符 0 空字符 r 回车符 ddd 位型 这里ddd是1至3位八进制数字f 换页符 0 xff 位型 这里ff是1至2位十六进制数字,注意:转义序列实际上作为一个字符来对待。但如果反斜线之后的字符和它不构成转义序列,则不起转义作用将被忽略。例如:语句 printf(ANbcnDEFn);语句 printf(tabrcdnefghx);,2.2 字符型数据,字符型变量是通过保留字char来说明的,其格式如下:char c1,c2;该语句说明了c1和c2两个字符型变量。每个字符型变量可用来存放一个字符,例如:#include“stdio.h”main()char ch;ch=getchar();putchar(ch);,2.2.2 字符型变量,2.2.3 字符型数据的存储表示,字符数据在计算机内部也是以一个字节的二进制形式来表示的,即事先对所要处理的每个字符都进行编码(通常是一个整型数)且不同的字符其编码也不相同。例如:,main()char c1,c2;c1=a;c2=b;c1=c1-32;c2=c2-32;printf(“c1=%c c2=%cn”,c1,c2);printf(“c1_ASCII_CODE=%d c2_ASCII_CODE=%dn”,c1,c2);运行结果:printf中的参数个数可以有多个,但第一个参数必须是字符串,我们称其为格式串(format-string)。,c1=A c2=Bc1_ASCII_CODE=65 c2_ASCII_CODE=65,2.2.3 字符型数据的存储表示,printf首先对格式串从左向右扫描,当遇到可显示字符时就在终端上原样输出,当遇到控制字符(如n,响铃符等)就产生相应的动作(换行,响铃等),当遇到转换符时,就将后面的实参依次按转换符的要求转换并输出。常用的转换符有:%d 十进制整型、%c 字符型、%f 浮点型、%s 字符串型在使用ASCII编码系统的机器上,用编写一个将大写英文字母转换为小写字母的程序,可用如下一些语句实现:char ch;ch=getchar();if(ch=A 若将上面程序中的字符常量A,Z和a分别用整常数65,90和97来代替程序能否正确运行?,2.2.3 字符型数据的存储表示,编译系统将字符型数据当成有符号整型还是无符号整型没有规定。例如:main()char ch;ch=376;printf(“%d”,ch);如果将字符看成无符号的,则输出254,否则,输出-2。字符量可参与任何整数运算,如:B-A=66-65=1;a+1=97+1=b 数字字符 整数值,如:9-0=57-48=9;9+0=9=48=57=9;字符量可以参加关系运算,如:ab=真字符量可以参加逻辑运算,如:a&b=真,2.2.3 字符型数据的存储表示,2.2.4 字符串常量,字符串常量是用一对双引号括起来的零个或多个字符的序列。如:“I am a student”,“x”,“”其中:“”只充当字符串的分界符,而不是字符串的一部分。如果字符串中要出现双引号,则必须经过转义序列,如:The“a”is an indef art 写成字符串应该是:“The 042a042 is an indef art”字符串中所含的字符个数称字符串的长度。例:“XYZ”的长度为3,“”的长度为0,称为空串。字符串所占的空间为长度+1,增加的一个字节存放字符串0作为字符串的结尾标志。转义序列也可以出现在字符串中。但是只作为一个字符看待。例如:“I am an student”。,2.3 浮点型数据,2.3.1 浮点型常量浮点型常量有非指数型和指数型两种。非指数型:是指不带指数部分的实型常数,如+123.,123.,-123,+123.45,123.45,-123.45指数型:是指带有指数部分的实数,如.12345e2,12345.0e-3,它们的值都是12.345。e(E)之前必须有数字,之后的指数必须为整数,且不能插入空格!2.3.2 浮点型变量浮点型变量是通过保留字float来说明的。如:,float x,y,z;x=12.345;y=.12345e2;z=12345.e-3;,2.3.3 浮点型数据的存储表示,浮点型数据的存储表示:二进制的浮点形式。如(0.5)10=(0.1)2=(.120)=(12-1)(12.1875)10=(1100.0011)2=(.1100001124)=(110000112-4)而任何一个二进制实数总可以表示成:N=S2p 其中:p、S都是有符号二进制整数。p称为阶码,S称为尾数 注意:S中无小数点或小数点约定为在最前头。设p的字长为n1,S的字长为n2,则有-2n1-1p2n1-1-1,-2n2-1S2n2-1-1,则一个实数的字长为:n1+n2。例如:设 n2=24 n1=8,则有:-128p127,-8388608S8388607 即 N=S2p 的取值范围是:2-128N2127,约为 10-39N1038 而N的精度大约为7位有效数字,2.4 双精度型数据,双精度型:字长比浮点型多一倍,一般占用8个字节。其中:(n2=48)+(n1=16)=64 其精度大约为17位有效数字,浮点型为7位精度;中每个浮点常量在机中都是以双精度型来存放和表示的;双精度变量是通过double保留字来说明的,如:double a,b;a=2.718281828459;b=4.84813681106e-7;,main()float x;double y;int i;x=0.0;y=0.0;i=1;while(i=10000)x=x+100000.0;y=y+100000.0;i=i+1;x=x/10000.0;y=y/10000.0;printf(“x=%f,y=%fn”,x,y,);运行结果为:可以看出x有约1.5的误差,而y没有精度损失。,2.4 双精度型数据,x=99985.179688,y=100000.000000,2.5 变量的初始化,程序中,在变量说明完之后到使用之前,要对其赋初值。如:int i,j;int i=0,j=0;i=0;j=0;while(i=15)while(i=15)两者是等效的。其它类型变量的初始化方法类似,如:int i=1,j,k=3;char bell=7,esc=27,sex=f;float pi=3.14159;double loge=2.718281828459;,2.6 变量的存储类,变量的两个属性:存在性和可见性存在性:是指变量都具有一个数据类型并以一定的方式存于内存之中。可见性:是指在其作用域中是可见的(活动的),而一旦出了其作用域便不再可见。变量的作用域:是指该变量有定义的程序部分。变量的以上两个属性是由以下四个变量存储类决定的:自动的(auto)寄存器(register)静态的(static)外部的(extern),2.6.1 自动变量,由保留字auto说明或定义的变量。例如:auto int a;auto char ch=x;auto float d,e;auto double f1,f2;Auto可省略不写自动变量是局部变量,其作用域局限于其所在的函数或块。自动变量每进入一次函数体,就赋一次指定的初值。,2.6.2 寄存器变量,寄存器变量是通过在变量说明前面加保留字register来完成的。寄存器变量的用法和作用域规定与自动变量相同。如:register int x=3;register char c1,c2;register float f1,f2;register double d1,d2;变量保留在CPU的寄存器中,只是对编译程序的一种建议,而不是强制性的。寄存器变量无地址,无法对其进行求地址运算。寄存器变量说明应尽量靠近其使用的地方,用完后尽快释放。,2.6.3 静态变量,静态变量是通过在变量说明前面加保留字static来说明的,如:static int x=1;static char c1;static float f1;static double d1,d2;静态局部变量的生存期一直延长到程序运行结束。静态局部变量不一定赋初值,编译时对无值的赋予0。静态局部变量的作用域与auto、register相同。,2.6.4 外部变量,外部变量是在函数外部任意位置上定义的全局变量。外部变量的作用域:从变量定义的位置开始,到整个源文件结束为止。外部变量的生存期:整个程序的运行期间。外部变量与局部变量同名时,外部变量被屏蔽。在每个引用外部变量的函数中都对相应的外部变量加以说明。例如:int x=123;main()extern int x,y;printf(“%dn%dn”,x,y);int y=321;,第2章 数据类型、运算符与表达式,2.1 程序设计概述2.2 C语言的数据类型2.3 常量和变量2.4 整型数据2.5 实型数据2.6 字符型数据2.7 算术运算与算术表达式2.8 赋值运算与赋值表达式2.9 C语言特有的运算和运算符Return,2.1 程序设计概述,一个程序应包括对数据的描述和对数据处理的描述。1对数据的描述,即数据结构。数据结构是计算机学科的核心课程之一,有许多专门著作论述,本课程就不再赘述。在C语言中,系统提供的数据结构,是以数据类型的形式出现的。2对数据处理的描述,即计算机算法。算法是为解决一个问题而采取的方法和步骤,是程序的灵魂。为此,著名计算机科学家沃思(Nikiklaus Wirth)提出一个公式:数据结构+算法=程序 实际上,一个程序除了数据结构和算法外,还必须使用一种计算机语言,并采用结构化方法来表示。Return,2.2 C语言的数据类型,C语言提供的数据结构,是以数据类型形式出现的。具体分类如下:1.基本类型分为整型、实型(又称浮点型)、字符型和枚举型四种。2.构造类型分为数组类型、结构类型和共用类型三种。3.指针类型。在第9章中介绍。4.空类型C语言中的数据,有常量和变量之分,它们分别属于上述这些类型。本章将介绍基本类型中的整型、实型和字符型三种数据。Return,2.3 常量和变量,2.3.1 常量 1.常量的概念 在程序运行过程中,其值不能被改变的量称为常量。2.常量的分类(1)整型常量(2)实型常量(3)字符常量。(4)符号常量。常量的类型,可通过书写形式来判别。2.3.2 变量1.变量的概念在程序运行过程中,其值可以被改变的量称为变量。2.变量的两个要素,(1)变量名。每个变量都必须有一个名字变量名,变量命名遵循标识符命名规则。(2)变量值。在程序运行过程中,变量值存储在内存中。在程序中,通过变量名来引用变量的值。.标识符命名规则(1)有效字符:只能由字母、数字和下划线组成,且以字母或下划线开头。(2)有效长度:随系统而异,但至少前个字符有效。如果超长,则超长部分被舍弃。例如,由于student_name和student_number的前个字符相同,有的系统认为这两个变量,是一回事而不加区别。在TC V2.0中,变量名(标识符)的有效长度为个字符,缺省值为。,(3)C语言的关键字不能用作变量名。注意:C语言对英文字母的大小敏感,即同一字母的大小写,被认为是两个不同的字符。习惯上,变量名和函数名中的英文字母用小写,以增加可读性。思考题:在C语言中,变量名total与变量名TOTAL、ToTaL、tOtAl等是同一个变量吗?标识符命名的良好习惯见名知意:所谓“见名知意”是指,通过变量名就知道变量值的含义。通常应选择能表示数据含义的英文单词(或缩写)作变量名,或汉语拼音字头作变量名。例如,name/xm(姓名)、sex/xb(性别)、age/nl(年龄)、salary/gz(工资)。,4.变量的定义与初始化在语言中,要求对所有用到的变量,必须先定义、后使用;且称在定义变量的同时进行赋初值的操作为变量初始化。(1)变量定义的一般格式 存储类型 数据类型 变量名,变量名2;例如,float radius,length,area;(2)变量初始化的一般格式存储类型 数据类型 变量名=初值,变量名2=初值2;例如,float radius=2.5,length,area;Return,2.4 整型数据,2.4.1 整型变量 1.分类 根据占用内存字节数的不同,整型变量又分为类:(1)基本整型(类型关键字为int)。(2)短整型(类型关键字为short int)。(3)长整型(类型关键字为long int)。(4)无符号整型。无符号型又分为无符号基本整型(unsigned int)、无符号短整型(unsigned short)和无符号长整型(unsigned long)三种,只能用来存储无符号整数。2.占用内存字节数与值域 上述各类型整型变量占用的内存字节数,随系统而异。在16位操作系统中,一般用字节表示一个int型变量,且long型(字节)int型(字节)short型(字节)。,显然,不同类型的整型变量,其值域不同。占用内存字节数为n的(有符号)整型变量,其值域为:-2n*8-1(2n*8-1-1);无符号整型变量的值域为:0(2n*8-1)。例如,PC机中的一个int型变量,其值域为-22*8-1(22*8-1-1),即-3276832767;一个unsigned型变量的值域为:0(22*8-1),即065535。2.4.2 整型常量.三种表示形式整型常量即整常数,在语言中可用三种形式表示:(1)十进制。例如10、36。(2)八进制(以数字开头)。例如012。(3)十六进制(以数字+小写字母x开头)。例如0 x36。,.分类(1)基本整型。在16位机中,用2字节存储,其数据范围与int型变量一样。(2)长整型(在数值后面加“L(l)”)。对超出基本整型值域的整型常量,可使用长整型常量表示,其取值范围可达-(-)。例如,123l、315等。.类型匹配规则类型匹配规则为:一个整型常量,可以赋给能容纳下其值的整型变量。例如,其值在-(-)的整型常量,可以赋给int型变量和long int型变量;其值在-(-)的整型常量,就只能赋给long int型变量。注意:常量无unsigned型。但一个非负整型常量,只要它的值不超过相应变量的值域(即取值范围),也可以赋给unsigned型变量。Return,2.5 实型数据,2.5.1 实型变量 语言的实型变量,分为两种:(1)单精度型。类型关键字为float,一般占字节(位)、提供位有效数字。(2)双精度型。类型关键字为double,一般占个字节、提供1516位有效数字。2.5.2 实型常量.表示形式实型常量即实数,在语言中又称浮点数,其值有两种表达形式:(1)十进制形式。例如3.14、9.8。(2)指数形式:E(e)。例如3.0+5等。.关于类型 实型常量不分float型和double型。一个实型常量,可以赋给一个实型变量(float型或double型)。Return,2.6 字符型数据,2.6.1 字符常量1.字符常量的定义用一对单引号括起来的单个字符,称为字符常量。例如,A、等。2.转义字符语言还允许使用一种特殊形式的字符常量,就是以反斜杠“”开头的转义字符。注意:如果反斜杠或单引号本身作为字符常量,必须使用转义字符:、。案例2.1 用转义字符输出可打印字符和不可打印字符。/*案例代码文件名:AL2_1.C*/*程序功能:用转义字符输出可打印字符和不可打印字符*/,main()printf(“x4Fx4Bx21n”);/*等价于printf(“OK!n”);*/printf(“x15 xABn”);程序运行结果如下:!程序演示 2.6.2 字符变量字符变量的类型关键字为char,一般占用1字节内存单元。1.变量值的存储 字符变量用来存储字符常量。将一个字符常量存储到一个字符变量中,实际上是将该字符的ASCII码值(无符号整数)存储到内存单元中。例如,char ch1,ch2;/*定义两个字符变量:ch1,ch2*/ch1=a;ch2=b;/*给字符变量赋值*/,2.特性字符数据在内存中存储的是字符的ASCII码 一个无符号整数,其形式与整数的存储形式一样(如图2-4所示),所以语言允许字符型数据与整型数据之间通用。(1)一个字符型数据,既可以字符形式输出,也可以整数形式输出。案例2.2 字符变量的字符形式输出和整数形式输出。/*案例代码文件名:AL2_2.C*/*程序功能:用字符形式和整数形式输出字符变量*/main()char ch1,ch2;ch1=a;ch2=b;printf(“ch1=%c,ch2=%cn”,ch1,ch2);printf(“ch1=%d,ch2=%dn”,ch1,ch2);程序运行结果:ch1=a,ch2=b ch1=97,ch2=98 程序演示,(2)允许对字符数据进行算术运算,此时就是对它们的ASCII码值进行算术运算。案例2.3 字符数据的算术运算。/*案例代码文件名:AL2_3.C*/*程序功能:字符数据的算术运算*/main()char ch1,ch2;ch1=a;ch2=B;/*字母的大小写转换*/printf(“ch1=%c,ch2=%cn”,ch1-32,ch2+32);/*用字符形式输出一个大于256的数值*/printf(ch1+200=%dn,ch1+200);printf(ch1+200=%cn,ch1+200);printf(ch1+256=%dn,ch1+256);printf(ch1+256=%cn,ch1+256);,程序运行结果:ch1=A,ch2=bch1+200=297ch1+200=)ch1+256=353ch1+256=a 程序演示思考题:用字符形式输出一个大于256的数值,会得到什么结果?2.6.3 字符串常量1.字符串常量的概念和字符串长度字符串常量是用一对双引号括起来的若干字符序列。字符串中字符的个数称为字符串长度。长度为0的字符串(即一个字符都没有的字符串)称为空串,表示为“”(一对紧连的双引号)。,例如,“How do you do.”、“Good morning.”等,都是字符串常量,其长度分别为14和13(空格也是一个字符)。如果反斜杠和双引号作为字符串中的有效字符,则必须使用转义字符。例如:(1)C:msdosv6.22 C:msdosv6.22(2)I say:Goodbye!I say:Goodbye!“2.字符串的存储C语言规定:在存储字符串常量时,由系统在字符串的末尾自动加一个0作为字符串的结束标志。注意:在源程序中书写字符串常量时,不必加结束字符0,否则画蛇添足。如果有一个字符串为“CHINA”,则它在内存中的实际存储如下所示:最后一个字符0是系统自动加上的,它占用字节而非字节内存空间。,综上所述,字符常量A与字符串常量A是两回事:(1)定界符不同:字符常量使用单引号,而字符串常量使用双引号;(2)长度不同:字符常量的长度固定为1,而字符串常量的长度,可以是0,也可以是某个整数;(3)存储要求不同:字符常量存储的是字符的ASCII码值,而字符串常量,除了要存储有效的字符外,还要存储一个结束标志0。Return,2.7 算术运算与算术表达式,在语言中,除控制语句和输入输出函数外,其它所有基本操作都作为运算符处理。1.五种基本算术运算符+、-(减法/取负)、*、/、%(求余数)(1)关于除法运算/C语言规定:两个整数相除,其商为整数,小数部分被舍弃。例如,5/2=2。(2)关于求余数运算要求两侧的操作数均为整型数据,否则出错。2.表达式和算术表达式(1)表达式的概念 用运算符和括号将运算对象(常量、变量和函数等)连接起来的、符合语言语法规则的式子,称为表达式。,单个常量、变量或函数,可以看作是表达式的一种特例。将单个常量、变量或函数构成的表达式称为简单表达式,其它表达式称之为复杂表达式。(2)算术表达式的概念表达式中的运算符都是算术运算符。例如,3+6*9、(x+y)/2-1等,都是算术表达式。良好的源程序书写习惯:在表达式中,在双目运算符的左右两侧各加一个空格,可增强程序的可读性。请比较表达式“(x+y)/2 1”与“(x+y)/21”,您认为哪个的可读性更好一些?3.运算符的优先级与结合性(1)语言规定了运算符的优先级和结合性。所谓结合性是指,当一个操作数两侧的运算符具有相同的优先级时,该操作数是先与左边的运算符结合,还是先与右边的运算符结合。,自左至右的结合方向,称为左结合性。反之,称为右结合性。结合性是语言的独有概念。除单目运算符、赋值运算符和条件运算符是右结合性外,其它运算符都是左结合性。(2)表达式求值1)按运算符的优先级高低次序执行。例如,先乘除后加减。2)如果在一个运算对象(或称操作数)两侧的运算符的优先级相同,则按语言规定的结合方向(结合性)进行。例如,算术运算符的结合方向是“自左至右”,即:在执行“a b+c”时,变量b先与减号结合,执行“a-b”;然后再执行加c的运算。,4.数据类型转换(1)在语言中,整型、实型和字符型数据间可以混合运算(因为字符数据与整型数据可以通用)。如果一个运算符两侧的操作数的数据类型不同,则系统按“先转换、后运算”的原则,首先将数据自动转换成同一类型,然后在同一类型数据间进行运算。转换规则如图2-5所示。1)横向向左的箭头,表示必须的转换。char和short 型必须转换成 int 型,float型必须转换成double型。2)纵向向上的箭头,表示不同类型的转换方向。例如,int型与double型数据进行混合运算,则先将int型数据转换成double型,然后在两个同类型的数据间进行运算,结果为double型。注意:箭头方向只表示数据类型由低向高转换,不要理解为int型先转换成unsigned型,再转换成long型,最后转换成double型。,(2)除自动转换外,语言也允许强制转换。数据类型强制转换的一般格式为:(要转换成的数据类型)(被转换的表达式)当被转换的表达式是一个简单表达式时,外面的一对圆括号可以缺省。例如,(double)a(等价于(double)(a)/*将变量a的值转换成double型*/(int)(x+y)/*将x+y的结果转换成int型*/(float)5/2(等价于(float)(5)/2)/*将5转换成实型,再除以2(=2.5)*/(float)(5/2)/*将5整除2的结果(2)转换成实型(2.0)*/注意:强制转换类型得到的是一个所需类型的中间量,原表达式类型并不发生变化。例如,(double)a 只是将变量a的值转换成一个double型的中间量,其数据类型并未转换成double型。Return,2.8 赋值运算与赋值表达式,1.赋值运算 赋值符号“=”就是赋值运算符,它的作用是将一个表达式的值赋给一个变量。赋值运算符的一般形式为:变量=赋值表达式 例如,x=5 y=(float)5/2 如果表达式值的类型,与被赋值变量的类型不一致,但都是数值型或字符型时,系统自动地将表达式的值转换成被赋值变量的数据类型,然后再赋值给变量。思考题:假设变量num的数据类型为float,其值为2.5,则执行“num=(int)num”后,num的值等于多少?,2.复合赋值运算复合赋值运算符是由赋值运算符之前再加一个双目运算符构成的。复合赋值运算的一般格式为:变量 双目运算符=表达式 复合赋值运算符它等价于:变量=变量 双目运算符(表达式)。当表达式为简单表达式时,表达式外的一对圆括号才可缺省,否则可能出错。例如,x+=3/*等价于x=x+3*/y*=x+6/*等价于y=y*(x+6),而不是y=y*x+6*/C语言规定的10种复合赋值运算符如下:+=,-=,*=,/=,%=;/*复合算术运算符(5个)*/&=,=,|=,=;/*复合位运算符(5个)*/,3.赋值表达式由赋值运算符或复合赋值运算符,将一个变量和一个表达式连接起来的表达式,称为赋值表达式。(1)一般格式 变量(复合)赋值运算符 表达式(2)赋值表达式的值任何一个表达式都有一个值,赋值表达式也不例外。被赋值变量的值,就是赋值表达式的值。例如,“a=5”这个赋值表达式,变量a的值“”就是它的值。Return,2.9 C语言特有的运算和运算符,2.9.1 自增(+)、自减(-)运算 1.作用 自增运算使单个变量的值增,自减运算使单个变量的值减。2.用法与运算规则 自增、自减运算符都有两种用法:(1)前置运算运算符放在变量之前:变量、变量 先使变量的值增(或减),然后再以变化后的值参与其它运算,即先增减、后运算。(2)后置运算运算符放在变量之后:变量、变量 变量先参与其它运算,然后再使变量的值增(或减),即先运算、后增减。,案例2.4 自增、自减运算符的用法与运算规则示例。/*案例代码文件名:AL2_4.C*/*程序功能:自增、自减运算符的用法与运算规则示例*/main()int x=6,y;printf(x=%dn,x);/*输出x的初值*/y=+x;/*前置运算*/printf(y=+x:x=%d,y=%dn,x,y);y=x-;/*后置运算*/printf(y=x-:x=%d,y=%dn,x,y);程序运行结果:x=6y=+x:x=7,y=7y=x-:x=6,y=7 程序演示,思考题:如果将案例“y=+x;”语句中的前置运算改为后置(y=x+;),“y=x-;”语句中的后置运算改为前置(y=-x;),程序运行结果会如何?3.说明(1)自增、自减运算,常用于循环语句中,使循环控制变量加(或减),以及指针变量中,使指针指向下(或上)一个地址。(2)自增、自减运算符,不能用于常量和表达式。例如,5+、-(a+b)等都是非法的。(3)在表达式中,连续使同一变量进行自增或自减运算时,很容易出错,所以最好避免这种用法。2.8.2 逗号运算(,)及其表达式语言提供一种用逗号运算符“,”连接起来的式子,称为逗号表达式。逗号运算符又称顺序求值运算符。,1.一般形式 表达式,表达式,表达式n2.求解过程自左至右,依次计算各表达式的值,“表达式n”的值即为整个逗号表达式的值。例如,逗号表达式“a=3*5,a*4”的值=60:先求解a=3*5,得a=15;再求a*4=60,所以逗号表达式的值=60。又例如,逗号表达式“(a=3*5,a*4),a+5”的值=20:先求解a=3*5,得a=15;再求a*4=60;最后求解a+5=20,所以逗号表达式的值=20。注意:并不是任何地方出现的逗号,都是逗号运算符。很多情况下,逗号仅用作分隔符。Return,

    注意事项

    本文(第2章 C语言的基本数据类型和存储类&数据类型、运算符与表达式.ppt)为本站会员(文库蛋蛋多)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开