C程序设计初步知识.ppt_第1页
C程序设计初步知识.ppt_第2页
C程序设计初步知识.ppt_第3页
C程序设计初步知识.ppt_第4页
C程序设计初步知识.ppt_第5页
已阅读5页,还剩47页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

,第2章C程序设计的初步,1.1认识C语言程序1.程序实例#include/*预编译命令,将标准输入输出函数作为头文件包括到用户源文件中*/main()/*主函数,名为main*/*函数体.开始*/floata,b,area;/*说明部分.定义变量类型*/a=1.2,b=30.0;/*执行部分.赋值语句*/area=a*b;/*执行部分.赋值语句*/printf(“a=%f,b=%f,area=%fn”,a,b,area);/*执行部分.输出语句*/*函数体.结束*/*/表注释,成对出现.不能嵌套,2.1简单的C程序设计,1.2实例总结1.C程序结构,预编译命令,主函数main()函数体开始说明部分;必须写在执行部分前执行部分;函数体结束,2.2标识符、常量、变量2.2.1标识符标识符定义:用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列。标识符命名规则(1)有效字符:只能由字母(AZ,az)、数字(09)和下划线组成,且以字母或下划线开头。(2)有效长度:随系统而异,但至少前个字符有效。如果超长,则超长部分被舍弃。例如,由于student_name和student_number的前个字符相同,有的系统认为这一个变量,是一回事而不加区别。例:判断下列哪些可做C中的标识符?area456PPI_asfa#Dc.wP203p,注意:C语言对英文字母的大小敏感,即同一字母的大小写,被认为是两个不同的字符。习惯上,变量名和函数名中的英文字母用小写,以增加可读性。思考题:在C语言中,变量名total与变量名TOTAL、ToTaL、tOtAl等是同一个变量吗?标识符命名的良好习惯见名知意:所谓“见名知意”是指,通过变量名就知道变量值的含义。通常应选择能表示数据含义的英文单词(或缩写)作变量名,或汉语拼音字头作变量名。例如,name/xm(姓名)、sex/xb(性别)、age/nl(年龄)、salary/gz(工资)。,一、关键字有固定含义,不能另作它用来。TC2.0有43个下表列出了C语言的所有关键字:autoenumrestrictunsignedbreakexternreturnvoidcasefloatshortvolatilecharforsignedwhileconstgotosizeof_Boolcontinueifstatic_Complexdefaultinlinestruct_Imaginarydointswitchdoublelongtypedefelseregisterunion例如:intdouble;关键字,不能另作它用。否则:是一种语法错误,不能通过编译!,标识符的分类,auto:声明自动变量一般不使用double:声明双精度变量或函数int:声明整型变量或函数struct:声明结构体变量或函数break:跳出当前循环else:条件语句否定分支(与if连用)switch:用于开关语句long:声明长整型变量或函数case:开关语句分支enum:声明枚举类型register:声明积存器变量typedef:用以给数据类型取别名(当然还有其他作用)char:声明字符型变量或函数extern:声明变量是在其他文件正声明(也可以看做是引用变量)return:子程序返回语句(可以带参数,也看不带参数)union:声明联合数据类型const:声明只读变量float:声明浮点型变量或函数short:声明短整型变量或函数unsigned:声明无符号类型变量或函数continue:结束当前循环,开始下一轮循环for:一种循环语句(可意会不可言传)signed:生命有符号类型变量或函数void:声明函数无返回值或无参数,声明无类型指针(基本上就这三个作用)default:开关语句中的“其他”分支goto:无条件跳转语句sizeof:计算数据类型长度volatile:说明变量在程序执行中可被隐含地改变do:循环语句的循环体while:循环语句的循环条件static:声明静态变量if:条件语句,二、预定义标识符预定义标识符是系统定的,具有特定含义。C语言提供的库函数名和编译预处理命令(宏替换define宏终止undef文件包含include动态存储分配函数mallocfreecalloc)等构成了预定义标识符。如重新定义另作他用时,失去原预定义的原意。建议不要另作他用。如printf,scanf。,三、用户标识符用户根据自己需要定义。一般用来给变量、函数、数组等命名。定义时,注意见名知义,增强程序的可读性。当用户标识符和关键字相同时,系统编译出错;当用户标识符和预定义标识符相同时,系统编译没有提示,但预定义标识符失去原定含义,代之用用户确认的含义。,C语言的关键字不能用作变量名(用户标识符)。预定义标识符尽量不用作变量名(用户标识符)。,数据:能够输入到计算机并由计算机进行处理的对象每一数据具有各自的数据类型。数据类型决定数据在内存中的存储长度和存储格式,C语言程序中,数据一般以常量或变量来体现,程序需对大量的常量或变量进行数据处理和计算。常量分为:字面常量和符号常量2.2.2常量P9(字面常量)1、常量是指程序运行中其值不能被改变的量。2、包括:整型常量、实型常量、字符常量、字符串常量;3、基本整型常量只能用数字表示,不带小数点;4、实型常量,必须带小数点;0.00.05、字符常量用一个字符表示;6、字符串常量,用“一串字符”表示;,例:说明下列数据是分别是什么类型的常量?12.34-22.9-.7as“a”“a”beng-90.89C语言可直接从形式上,确定是什么类型的常量。,2.2.3符号常量用一个符号代表一个常量;这个符号名必须在程序中特别的“指定”,并符合标识符的命名规则;其指定的方法,例2.2#define宏名替换文本含义是:将源程序中所有宏名的标识符用替换文本替换。,用户定义的标识符(不得与程序中其它名字相同),为和普通变量区别一般采用大写,符号常量在使用之前需通过#define命令定义。如:#definePI3.14159定义了一个符号常量PI,从此定义点之后,PI将一直代表3.14159。还有例2-1中的PRICE也是一个符号常量,它对应的就是常量值20。在必要的时侯引入符号常量有以下好处:,例2-1:程序中的常量和变量。#definePRICE20main()intnum,total;/*将变量名改用main和define会怎样?*/num=5;total=num*PRICE;/*可不可以将PRICE写成price?*/printf(total=%d,total);运行结果为,在显示器上显示:total=100,用标识符代表一个常量,称为符号常量。符号常量与变量不同,它的值在其作用域内不能改变,也不能再被赋值。(PI=9.9X)使用符号常量的好处是:含义清楚;能做到“一改全改”。作业思考:P10例:1、判断程序中标识符的类型(关键字)(预定义标识符、用户自定义标识符)、常量、变量?,2.2.4变量指在程序运行过程中其值可变的量;变量名由用户标识符表示;变量名的实质:代表着某一个内存单元;例:变量a-某个内存单元的名字叫a规定:C语言中,所有的变量必须先定义、说明其类型后使用;系统在编译时,根据其类型为其分配存储单元的大小.该定义可放在函数体内的前部(一般)或函数的外部或者复合语句的开头看PPT17中的变量,2.3整型数据,2.3.1整型常量.三种表示形式整型常量即整常数,在语言中可用三种形式表示:(1)十进制。例如10、36。(2)八进制(以数字开头)。例如012。(3)十六进制(以数字+小、大写字母xX开头)。例如0 x36注意:C程序中,只有十进制可以是负数。2.分类根据占用内存字节数的不同,整型常量又分为类:(1)基本整型(类型关键字为int)。(2)短整型(类型关键字为shortint)。(3)长整型(类型关键字为longint)。(4)无符号整型。无符号型又分为无符号基本整型(unsignedint)、无符号短整型(unsignedshort)和无符号长整型(unsignedlong)三种,只能用来存储无符号整数。,2.3.2整型变量P111.分类根据占用内存字节数的不同,整型变量又分为类:(1)基本整型(类型关键字为int)。(2)短整型(类型关键字为shortint)。(3)长整型(类型关键字为longint)。(4)无符号整型。无符号型又分为无符号基本整型(unsignedint)、无符号短整型(unsignedshort)和无符号长整型(unsignedlong)三种,只能用来存储无符号整数。所有的变量必须先定义并说明其类型后使用;intk;doubler,s;inti,j=0,k=2;,2.占用内存字节数与值域C标准中,没有具体地规定各类型整型数据所占的内存空间的大小,只是要求long=int=short,具体如何实现由各计算机系统自行决定见表2.1VC6.0中定义的整型数所占用的字节数和数值范围,2.3.4整数在内存中的存储形式内存的最小存储单位-位bit(存放0或1)字节:1byte=8bit字word:用一个字来存放一条机器指令或一个数据.P12一、正整数如:short类型的正整数5在内存中存放为:0000000000000101(long?)正整数按“原码”形式存放,最大的short类型的正整数是:0111111111111111(32767),二、负整数1、负整数在内存中以“补码”形式存放。例:-5在内存中的存放形式为:10000101负数原码=11111010=11111011=存入2、已知内存中存放的负数,求其原码11111010=10000101=-5=-6存放的负数练习:(1)-12存放形式(2)负数10111100的原码,除符号位外,取反码,加1,除符号位外,取反码,转化为十进制,减1,三、无符号整数最高位不再用来存放整数的符号.其不能表示负数1111111111111111=代表65535?为什么不是-1,2.4实型数据,2.4.1实型常量十进制小数形式,如:100.0、0.5、-10.8等,注意实型常量中必须要有一个小数点指数形式,如:100e5表示100105,注意字母E(或e)之前必须有数字,且E(或e)后面的指数必须为整数,如E5、1.5e3.8、1e等都是不合法的指数形式规范化的指数形式字母E(或e)之前的小数部分,其小数点之前必须有且只能有一位非零的数值。如:3.58759E2下列哪些指数形式是合法,哪些不是规范的指数形式?.34e-978.0E2e3.E-212e53.322E-0.2,2.实型变量及其定义,C语言中的实型变量分为单精度型和双精度型两种,分别用保留关键字float和double进行定义。例如:floatx,y;/*说明变量x,y为单精度实型*/doublez;/*说明变量z为双精度实型*/,3.实型数据分类,在大多数C编译系统中,将实型常量都作为双精度型来处理。例如:floata;doubleb;a=111111.111;/*最后两位小数不起作用*/b=111111.111;,4.实型数据在内存中的存储形式,实型数据在内存中是按照指数的形式来存储的。如图2.2所示。,由于实型数据在内存中的存储位数是固定的,也是有限的,所以实型数据的精度不是很高,所能表示的数据范围也是有限的。而且由于实型数据的存储形式比较复杂,计算机在进行算术运算时的处理速度也比较慢。在计算机内可以精确地存放一个整数.不产生误差;而存放实数往往产生误差,5.实型数据的误差,由于用来存储实型数据的存储单元的位数有限,所以有效位数以外的其它数字位被舍去了。这种误差叫做存储误差。此外,在将十进制数转换成二进制数时,有时也会产生误差,即转换误差。,main()floatx1,x2;x1=288.4;/*有效位数不多,但会产生转换误差*/x2=1234567891.0;/*有效位数太多,会产生存储误差*/printf(x1=%fn,x1);printf(x2=%fn,x2);程序的运行结果为:x1=288.399994x2=1234567936.000000,例2.2实型数据的误差,2.5算术表达式,1.基本算术运算符有:、*、/、%注意事项两个整型数据相除的结果只能为整型数值,如72的结果为3“+”或“-”用作单目运算符时只能有一个运算量,如x=-5,则+x的值还是-5,而-x的值为+5。求余运算只能在两个整型数据之间进行,如9%5的值为4,而9.5%3为非法的运算,如-9%5的值为4或者-4当运算量为负数时,所得结果的符号未作明确的规定。TURBOC系统规定余数的符号与被除数相同。-双目运算符两边类型不一致时,系统自动进行类型转换;见课件P35-37-实型运算,系统皆转变为双精度方式进行;,2.算术表达式,用算术运算符和圆括号将函数和运算对象(如常量、变量等)按一定的规则连接起来就可以构成一个算术表达式,如:(ab)*c5.0、x*y2*sin(z)等都是算术表达式表达式都有一个值,即运算结果。应该注意表达式中运算符的优先级和结合性P15优先级用于决定运算中的运算顺序,即有多个运算符出现时,哪一个先计算,哪一个后计算。P15结合性则决定同一优先级的运算符之间的运算顺序,即是先左后右还是先右后左。P269附录,结合性是指,当一个操作数两侧的运算符具有相同的优先级时,该操作数是先与左边的运算符结合,还是先与右边的运算符结合。规定:优先级别高的先运算;同一级别的,除单目运算、赋值运算、条件运算外,结合性都是从左到右的;5+1/2(5+1)/25*-25*(-2),3.算术运算中的类型转换,在C语言中要求参加运算的两个运算量是同一数据类型,而运算结果也是该数据类型。对数据类型不一致的两个运算量,系统会进行数据类型转换,将其中的一个低级别类型的数据向另一个高级别类型的数据转换(按空间大小和数值范围),然后才进行相应的算术运算,运算的结果为其中高级别类型的数据。,隐式转换什么情况下发生运算转换-不同类型数据混合运算时赋值转换-把一个值赋给与其类型不同的变量时输出转换-输出时转换成指定的输出格式函数调用转换-实参与形参类型不一致时转换运算转换规则:不同类型数据运算时先自动转换成同一类型,3.强制类型转换运算符,当自动类型转换不能达到目的时,可以使用强制类型转换运算符。强制类型转换运算符就是用一对括号括起来的类型名标识符,其一般格式为:(类型名标识符)(表达式)例如:假设x为float类型,则表达式“x%3”是不合法的,因为%运算符要求其两侧的数据都必须是整型数据。可以使用表达式“(int)x%3”达到求余数的目的,即先将实型变量x强制转换为整型值,然后再进行取余运算。,显式转换(强制转换)一般形式:(类型名)(表达式)例x=3.2y=2求值:(int)(x+y)(int)x+y(double)(3/2)(int)3.6说明:强制转换得到所需类型的中间变量,原变量类型不变,例main()floatx;inti;x=3.6;i=(int)x;printf(“x=%f,i=%d”,x,i);结果:x=3.600000,i=3,精度损失问题,Ch2_007.c,Ch2_008.c,P15例,#includemain()doublex=3.2,z,k,l,p;inty=2;z=(int)(x+y);k=(int)x+y;l=(double)(3/2);p=(int)3.6;printf(%f,%f,%f,%f,z,k,l,p);,2.6赋值运算符与赋值表达式,变量的值在程序的运行过程中能够发生变化主要是通过对变量进行赋值来完成的。如果在程序中没有赋值操作,则变量的值也就不会发生变化。1.赋值运算符()的作用是把一个数据或表达式的值赋给一个变量。例如:x=3赋值运算符的左边只能是变量,不允许是算术表达式或常量。例如:x+1=3赋值运算符与数学中的等号不同,赋值运算符求解以后能够得到一个运算结果。赋值运算符的优先级别只高于逗号运算符,具有从右向左的结合性。a=b=9+b,2.赋值表达式,由赋值运算符将一个变量和一个表达式连接起来的式子称为赋值表达式。赋值表达式的一般形式为:变量=表达式例如:x=3*5执行过程:先将赋值运算符右边表达式的值求出来,然后将该值赋给左边的变量,被赋值变量的值就是整个赋值表达式的值。x=xn=n+1的含义P16P16说明,3.复合的赋值运算符,复合的赋值运算符是在赋值运算符的前面加上其它的运算符组合而成的新运算符。10种复合赋值运算符分别是:*%超出范围舍去=出错高类型向低类型转换.丢失精度2.将整型值转换为实型值时整数部分取整型值,小数部分的值为零。floatf=13;=结果f为13.000000,3.将双精度的实型数据转换为单精度的实型数据时截取其小数部分中前面的7位有效数字(十进制数),指数部分保持不变。超值错。floatx;doubley=33.423549993;x=y;内存中,x的值为33.423550高类型向低类型转换.丢失精度,赋值运算中的类型转换(续),4.将整型数据转换为取值范围更大的整型数据时,(低类型整型高类型整型)(1)对于有符号数,用其符号位的值向前扩展。,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论