《C语言基本数据类型.pptx》由会员分享,可在线阅读,更多相关《C语言基本数据类型.pptx(67页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、2.1 字符集及词法约定2.1.1 字符集(1)数字:我们平常使用的10个十进制数字:0,1,9。(2)字母:大、小写英文字母各26个:A,B,Z和a,b,z。大、小写字母是有区别的,表示不同的字符。第1页/共67页(3)图形符号:29个图形(可见)字符,即:!#%&()*+,/;:?_|(4)转义序列。表2-1列出了C语言源程序中常用到的一些转义序列及其含义。第2页/共67页字字 符符 名名表示形表示形式式含含 义义备备 注注换行换行n把打印(显示)位置移到下一行的起始位置把打印(显示)位置移到下一行的起始位置水平制表水平制表t把打印位置移到当前行的下一个制表点(通常是把打印位置移到当前行的
2、下一个制表点(通常是右移右移8个字符的间隔)个字符的间隔)与实现有关与实现有关表2-1转义序列及其含义第3页/共67页字字 符符 名名表示形式表示形式含含 义义备备 注注垂直制表垂直制表v把打印位置移到下一行制表点起始位置把打印位置移到下一行制表点起始位置与实现有关与实现有关退格退格b把打印位置在当前行上向后退一个字符位置把打印位置在当前行上向后退一个字符位置与实现有关与实现有关回车回车r把打印位置移到当前行的起始位置把打印位置移到当前行的起始位置换页换页f把打印位置移到下一个逻辑页开头的起始位置把打印位置移到下一个逻辑页开头的起始位置报警报警a产生可听或可见的报警,位置不变产生可听或可见的报
3、警,位置不变与实现有关与实现有关问号问号?打印问号打印问号单引号单引号打印单引号打印单引号双引号双引号打印双引号打印双引号反斜线反斜线打印一个反斜线打印一个反斜线续表第4页/共67页(1)标识符 在C语言中,用来标记常量、变量、数据类型、函数及程序的名字。必须符合下列语法规则:应以字母(大小写皆可)或下线符(_)中任一个字符开头。2.1.2 词法约定词法约定第5页/共67页 在第一个字母后,可以是任意字母、下线符和数字组成的字符序列,此序列可为空串。根据以上规则,下列字符序列是合法的标识符:NAME1 name1 Total_5 Paper _i3 _out第6页/共67页 而以下字符序列不是
4、合法的标识符:NAME 1 中间留有空格,它不是字母数字串name$2 中间有$,此为非字母、数字字符5t 开头的是数字,而不是字母$4 开头的是一般字符,不是字母第7页/共67页 程序中的标识符必须选择恰当。在选择标识符时,要尽量避免使用容易混淆的字符。C语言区分大、小写字母,所以name1、Name1和NAME1可在同一程序中使用,各代表不同的变量。标识符的最大长度还受实现的限制。第8页/共67页(2)关键字 在有些语言中关键字又称作保留字。它是具有特定含义、专门用作语言的特定成分的一类标识符。不能当作一般标识符使用。表2-2列出C语言的全部关键字及其用途。第9页/共67页关关 键键 字字
5、类类 型型用用 途途char数据类型数据类型字符量字符量int整型量整型量long长整型量长整型量short短整型量短整型量float单精度浮点量单精度浮点量double双精度浮点量双精度浮点量unsigned无符号量(最高位不作符号位)无符号量(最高位不作符号位)signed有符号量有符号量struct结构型量结构型量union联合型量联合型量enum枚举型量枚举型量void无值量无值量const常量常量volatile易变量易变量auto存储类存储类自动量自动量extern外部量外部量static静态量静态量register寄存器量寄存器量typedef类型命名类型命名表2-2关键字及其用
6、途第10页/共67页关关 键键 字字类类 型型用用 途途ifif流程控制流程控制条件语句条件语句elseelse条件语句的另一种选择条件语句的另一种选择forforforfor循环语句循环语句whilewhilewhilewhile和和do-whiledo-while循环语句循环语句dododo-whiledo-while语句语句breakbreak间断语句间断语句continuecontinue接续语句接续语句gotogoto跳转语句跳转语句returnreturn返回语句返回语句switchswitch多路选择语句多路选择语句defaultdefault多路选择语句中的默认情况多路选择语句
7、中的默认情况casecase多路选择语句中的情况选择多路选择语句中的情况选择sizeofsizeof运算符运算符计算字节数计算字节数续表第11页/共67页(3)标点符号 C语言中标点符号是表示语法的符号,共有13个,即:()*,:=;#第12页/共67页 程序中往往要用到一些预先给定值的量,并且在程序执行过程中其值不再发生变化。这类数据一般称为常量。2.2 常 量第13页/共67页 C语言中有不同类型的常量,如整型常量、浮点常量、字符常量和字符串常量。常量在C语言中出现的形式一般有两种:一种是在程序中直接使用给定的值,2和3.1415926都是固定不变的量,而且直接以值的形式出现。这种形式的常
8、量往往称为字面量。第14页/共67页 另一种形式是采用宏定义形式,例如:#define PI 3.1415926 经过宏定义之后,就用标识符来代表字面量,这种形式的常量通常称为符号常量。符号常量的名字往往用大写字母,不能把符号常量名当作变量使用。第15页/共67页 在C语言中,整常量分为十进制整常量、八进制整常量和十六进制整常量。普通整常量在机器中占一个字长。1十进制整常量 十进制整常量是带正负号的整数。如12,2008,10001,39。2.2.1 整型常量整型常量第16页/共67页 八进制整常量是以数字0开头的八进制数字串,其中只能出现数字07。通常,它是无符号数(即没有正负号的数)。2八
9、进制整常量八进制整常量第17页/共67页 十六进制整常量是以0 x或0X开头的十六进制数字串,可用的数字有09,af或AF。3十六进制整常量十六进制整常量第18页/共67页(1)无符号型后缀 无符号型后缀用小写字母u或者大写字母U表示(unsigned int)。例如,986u,07654u,0XFEDu等都是无符号整常量。4整常量的后缀整常量的后缀第19页/共67页(2)长型后缀 长型后缀用小写字母l或大写字母L表示(long int)。例如:62l,0123L,0 x327l等。如果一个整常量后面同时带有后缀l(L)和u(U),那么,它的类型就是unsigned long int(无符号长
10、整型)。例如:9999lu,077777LU等。第20页/共67页 它有以下两种表示形式。(1)十进制数形式 例如:3.14,0.618,.618,10.0,123.等都是合法的浮点常量。在这种形式中,一个浮点常量是由数字和小数点组成。必须有小数点,并且小数点的前面或者后面必须有数字。2.2.2 浮点常量浮点常量第21页/共67页(2)指数形式 例如:2.98e6(或2.98E6),3.0e8(或3.0E8),6.E5,6e5,.123E+4等都是合法的浮点常量。在这种形式中,必须带有阶码标志e(或E),并且e之前必须有数字,e之后的指数必须是整数。第22页/共67页 如果浮点常量不带后缀,那
11、么它的类型就是双精度型(double)。若在浮点常量后面带有后缀字母F或f,那么它的类型就是单精度浮点型(float),通常简称为浮点型。在浮点常量后面还可带有后缀字母l或L,此时,它的类型就是长双精度型(long double)。在一般系统中,单精度浮点数占用4个字节(32位)的存储单元,而双精度浮点数占用8个字节。第23页/共67页 在C语言中,字符常量是用单引号括起来的一个字符或字符序列,如 x、AB、9、*等。除以上形式外,构成字符常量的字符还可以是转义序列。在C语言中转义序列有三种:简单转义序列、八进制转义序列和十六进制转义序列。2.2.3 字符常量字符常量第24页/共67页(1)简
12、单转义序列?a b f n r t v 虽然在形式上它们是由两个字符构成的,却只代表一个字符。(2)八进制转义序列 它是由反斜线和后随的一个、两个或三个八进制数字构成的,如:014、75、6等。第25页/共67页(3)十六进制转义序列 它是由反斜线、字母x和后随的一个、两个或三个十六进制数字构成,如:x9、x1A、x123等。上述八进制转义序列和十六进制转义序列在构成形式上虽然出现多个字符,但在相应的字符常量或字符串常量中却只代表一个字符。如014、xB9等都分别是一个字符的含义。第26页/共67页 字符常量的类型是int。它的值就是该字符在相应字符集中的编码值。字符常量可像其他整数一样参与数
13、值运算。第27页/共67页 在语言中,用0表示空字符NUL,在机器中存放时它所占字节的各位都是0,因而它的值也是0。要注意,空字符不是空白字符。还应注意0与0的区别。空字符常用来标识一个字符串的结尾。第28页/共67页 它是用一对双引号括起来的零个或多个字符组成的序列,如:Hello!This is a character string1234567890(在双引号中没有任何字符)字符串常量也可以看成是一个数组,这个数组的元素为一个一个的字符。2.2.4 字符串常量字符串常量第29页/共67页 编译程序在编译源文件时会自动在每个字符串末尾放上空字符“0”,作为字符串的结尾,这种方式也表明:在C
14、程序中,对字符串的长度不加限制。一个字符串究竟有多长,要到达结尾字符“0”时才能确定。第30页/共67页 每个字符串所需要的实际空间要比用户给出的字符数多一个字节。x就不同于x。前者是单独一个字符,而后者是一个字符串,它包含了两个字符:字母“x”和一个空字符“0”。第31页/共67页 变量是在程序执行过程中其值可以改变的量。在程序中使用一个变量之前,先要对它进行定义:为它指定一个名称(变量名),指明它是什么类型的变量等。变量名应是合法的标识符。int i;int j;int k;2.3 简 单 变 量第32页/共67页 同时对几个有相同类型的变量进行定义,也可以简写在一行中,如:int i,j
15、,k;注意,int与i之间有空格,各变量名之间要用逗号隔开,最后一个变量名后面要用分号结尾。第33页/共67页 在C语言中定义变量的一般形式是:数据类型 变量名;或者数据类型 变量名1,变量名2,;第34页/共67页 定义变量时,还应注意以下几点。不同类型的变量应在各自数据说明行上定义,不要把它们统统写在一行上,以增加程序的可读性。第35页/共67页 在程序的同一部分,不允许对同一标识符做重复定义。例如:1main()23 int a,b,sum;4 float price,sum;5 char a,flag;第36页/共67页 数据说明语句是以分号结尾,而同一说明语句中各个变量名之间以逗号隔
16、开。例如:int i,j,k;第37页/共67页2.4 基本数据类型及其转换C C语言数据类语言数据类型型基本类型基本类型字符型字符型整型整型浮点型浮点型双精度型双精度型表2-3C语言数据类型 第38页/共67页C C语言数据类语言数据类型型枚举类型枚举类型枚举型枚举型无值型无值型导出类型导出类型数组数组结构结构联合联合函数函数指针型指针型续表 第39页/共67页2.4.1 整型整型int及其相关类型及其相关类型 在C语言中,表示整型量的关键字是int,所以一个整型变量i的说明形式为:int i;在目前大多数实现中,整型变量的取值范围因机器字长而异。在字长为16位的机器上,整型变量i的取值范围
17、是:32768i32767第40页/共67页 对它们可以施行如下算术运算:+(加)(减)(乘)(除)(取模)整数还可使用下述运算符进行关系运算:=!=第41页/共67页 C语言中与int有关的类型还有:(1)短整型short int,简写为short。(2)长整型long int,简写为long。(3)无符号整数unsigned int,简写为unsigned。第42页/共67页 表示字符型变量的关键字是char。char c;一个字符型变量所占用的内存空间应足以存放所用基本字符集中任何一个字符,通常占用一个字节,即8位。2.4.2 字符型字符型char及其相关类型及其相关类型第43页/共67
18、页 在ANSI C和ISO C中,还规定了signed char和unsigned char两种类型,unsigned char型量的取值范围是0255,而signed char型量的取值范围是127127。第44页/共67页 当把一个字符常量赋给一个字符变量时,该字符变量的值就是相应字符的编码值。在C语言中字符数据往往可以像整型数据那样进行有关运算。第45页/共67页 例2-1 在ASCII字符集中,字母A的序号为65,分析以下程序的输出结果。#include main()char x,y;x=A+10;y=Z 20;printf(%c=%d,%c=%d n ,x,x,y,y);return
19、(0);第46页/共67页 字符数据可以以字符形式输出,也可以用整数形式输出。第47页/共67页 表示基本浮点类型的关键字是float。float f;C语言中还提供其他两种浮点类型:double和long double,分别称作双精度类型和长双精度类型。float量的取值范围是double量的子集,而double量的取值范围又是long double量的子集。2.4.3 浮点型浮点型float第48页/共67页 一般机器上float量占4个字节(32位),double量占8个字节(64位),而long double量要占16个字节(128位)。浮点变量可进行的算术运算有下述4种:+*第49页
20、/共67页 其运算结果仍是一个浮点量。但大家应注意,取模运算符“%”不能作用于浮点量上。为了保持运算精度,在运算时所有的float量都被转换成double量。第50页/共67页int i=10;float pi=3.14;double f;f=i*pi;2.4.4 类型转换类型转换第51页/共67页 不同类型的量在一起进行算术运算时需进行类型转换。即:如果一个运算符有两个不同类型的运算分量,那么,在操作之前先将“较低”的类型提升为“较高”的类型,使二者类型统一,然后进行操作;其结果是“较高”类型。而类型的高低是由其属性(取值范围、精度、作用等)来决定的。第52页/共67页 由算术运算符对运算分
21、量自动实施的类型转换称为普通算术转换,也称为隐式转换。第53页/共67页图2-1 算术转换规则第54页/共67页 在进行运算之前,所有char型和short型数据都转换成int型,所有float型数据都转换成double型,从而可以提高运算精度。在赋值语句中,赋值号右边表达式的值的类型要转换成赋值号左边变量的类型。第55页/共67页例如:int i=10;float pi=3.14;double f;f=i*pi;第56页/共67页 例2-2 分析下面程序输出的结果。/*Basic conversions in C*/main()int a,b=550;char c=7;float f1=3.
22、142,f2;a=b/c;/*integer divided by a character*/printf(a=%dn,a);第57页/共67页a=f1;/*float to integer conversion*/printf(f1=%fa=%dn,f1,a);f1=b;/*integer to float conversion*/printf(b=%df1=%fnb,f1);f2=b/50.0;/*integer divided by a float*/printf(b=%d,f2=%fn,b,f2);return(0);第58页/共67页 输出结果是:a=10f1=3.142000a=3
23、b=550f1=550.000000b=550,f2=11.000000第59页/共67页 C语言中除上述隐式类型转换外,还有显式类型转换,这就是利用类型强制转换运算符“(类型名)表达式”形式中的一对圆括号,强行把其后表达式的类型转换成圆括号中给定的类型。第60页/共67页(1)printf()函数 printf()函数的功能是按指定的输出格式把相应的参数值在标准输出设备(通常是终端)上显示出来。2.5 printf和scanf函数的一般使用第61页/共67页 printf()的一般使用格式是:printf(格式控制串,参数1,参数2,);例如:printf(The value=%d*%dn,
24、a,b);第62页/共67页转转 换换 说说 明明输输 出出 形形 式式应应 用用 例例 子子输输 出出 示示 例例%d%d十进制十进制intint型型printf(sum=%d printf(sum=%d n,sum);n,sum);sum=2008sum=2008%f%f十进制十进制doubledouble型型printf(a=%f n,a);printf(a=%f n,a);a=6.280000a=6.280000%c%c单个字符单个字符printf(“It is%c printf(“It is%c n,c);n,c);It is MIt is M%s%s字符串字符串printf(*%s
25、*printf(*%s*n,s);n,s);*Hello!*Hello!*%o%o无符号八进制数无符号八进制数printf(Oct=%o printf(Oct=%o n,oct);n,oct);Oct=176Oct=176%x%x无符号十六进制数无符号十六进制数printf(Hex=%x printf(Hex=%x n,hex);n,hex);Hex=96AFHex=96AF%本身本身printf(a%b=%d printf(a%b=%d n,d);n,d);a%b=5a%b=5表2-6 printf()中常用的转换说明及其作用第63页/共67页(2)scanf()函数 scanf()函数的功
26、能是接受用户从键盘上输入的数据,按照格式控制符的要求进行类型转换,然后送到由对应参数指示的变量单元中去。第64页/共67页 scanf()的一般使用格式是:scanf(格式控制串,参数1,参数2,);例如:scanf(%d%f ,&a,&r);第65页/共67页转转 换换 说说 明明输输 入入 形形 式式 应应 用用 例例 子子输输 入入 示示 例例%d匹配可带符号的十进制匹配可带符号的十进制整数整数scanf(%d,&a);输入输入100,则,则a为为100%f匹配可带符号的浮点数匹配可带符号的浮点数scanf(%f,&f);输入输入3.14,则,则a为为3.140000%c匹配一个(默认)
27、字符匹配一个(默认)字符scanf(%c,&c);输入输入A,则,则c为为 A%s匹配非空白字符序列匹配非空白字符序列scanf(%s,line);输入输入string,则数组,则数组line中中放置放置string,末尾自动加,末尾自动加上空字符上空字符%o匹配可带符号的八进制匹配可带符号的八进制整数整数scanf(%o,&u);输入输入754,则,则u的值为八进的值为八进制制754%x匹配可带符号的十六进匹配可带符号的十六进制整数制整数scanf(%x,&x);输入输入123,则,则x值为十六进值为十六进制制123表2-7scanf()中常用的转换说明及其作用第66页/共67页感谢您的欣赏!第67页/共67页