今天我在学习数据类型 运算符 表达式。其实这一章节并不是太难理解,但东西很多,虽然相互之间有连贯性,对比性,但是记忆起来还是麻烦的不得了。我因为以前有学过C语言,大致有个印象,所以看了一会就不看了,直接码出来。一来强迫自己再读下去,二来我认为自己还是会记不全,也方便后面查阅。
C语言的数据类型
在程序中使用的各种变量都应预先加以定义,即先定义,后使用。对变量定义可以包括三个方面:数据类型 存储类型 作用域。
现在,我们只介绍数据类型的说明。所谓数据类型是按被定义变量的性质,表示形式,占据存储空间的多少,构造特点来划分的。在C语言中,数据类型可分为:基本数据类型,构造数据类型,指针类型,空类型四大类。
1 基本数据类型包括:整型 字符型 实型(浮点型)【单精度类型 双精度类型】 枚举类型。
基本数据类型最主要的特点是,其值不可以再分解为其他类型。也就是说,基本数据类型是自我说明的。
2 构造类型包括:数组类型 结构体类型 共用体类型
构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。每个“成员”都是一个基本数据类型或又是一个构造类型。
3 指针类型:指针是一种特殊的,同时又是具有重要作用的数据类型。其值用来表示某个变量在内存储器中的地址。虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。
4 空类型:在调用函数值时,通常应向调用者返回一个函数值。这个返回值是具有一定的数据类型的,应在函数定义及函数说明中给以说明。但是,也有一类函数,调用后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。其类型说明符为void。
常量和变量
对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。在程序执行过程中,其值不发生改变的量称为常量,其值可改变的量称为变量。***它们可与数据类型结合起来分类。***例如,可分为整形常量、整形变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。在程序中,常量是可以不经说明而直接引用的,而变量则必须先定义后使用。
整型量包括整型常量、整形变量。
1 常量和符号常量
在程序执行过程中,其值不发生改变的量称为常量。
直接常量:整型常量 实型常量 字符常量。
标识符:用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列。
符号常量:用标识符代表一个常量。在C语言中,可以用一个标识符来表示一个常量,称之为符号常量。
符号常量在使用之前必须先定义,其一般形式为:
#define标识符 常量
其中#define也是一条预处理命令(预处理命令都以“#”开头),称为宏定义命令(在后面与处理程序中将进一步介绍),其功能是把该标识符定义为其后的常数量。一经定义,以后在程序中所有出现该标识符的地方均代之以该常数量。
1 用标识符代表一个常量,称为符号常量
2 符号常量与变量不同,它的值在定义域内不能改变,也不能再被赋值。
3 使用符号常量的好处:
1)含义清楚
2)能做到“一改全改”
2 变量
其值可以改变的量称为变量。一个变量应该有一个名字,在内存中占据一定的存储单元。变量定义必须放在使用之前。一般放在函数体的开头部分。要区分变量名和变量值是两个不同的概念。
整型数据
1 整型常量的表示方法
整型常数就是整常数。在C语言中,使用的整常数有八进制、十六进制和十进制三种。
1)十进制整常数:十进制整常数没有前缀。其数码为0-9.
在程序中是根据前缀来区分各种进制数的。因此在书写常数时不要把前缀弄错造成结果不正确。
2)八进制整常数:八进制整常数必须以0开头,即以0开头,即以0作为八进制的前缀。数码取值为0-7。八进制数通常是无符号数。
3)十六进制整常数:十六进制整常数的前缀为0x或0X.其数码取值为0-9,A-F或a-f。
4)整形常数的后缀:在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号常数的范围为0-65536,有符号数为-32768~+32768。八进制无符号数的表示范围为0-0177777。十六进制无符号数的表示范围为0X0-0XFFFF或0X0-0XFFFF。如果使用的数超过了上述范围,就必须用整型数来表示。长整型数是用后缀“L”或"l"来表示的。
无符号数也可用后缀表示,整形常数的无符号数的后缀为“U”或“u”。
2 整形变量
1 整型数据在内存中的存放形式
如果定义一个整型变量i:
int i;
i=10;
1)正数的补码和原码相同;
2)负数的补码:将该数的绝对值的二进制形式按位取反再加1。
2 整形变量的分类
1)基本型:类型说明符为int,在内存中占2个字节。
2)短整量:类型说明符为short int或short。所占字节和取值范围均与基本型相同。
3)长整型:类型说明符为long int或long,在内存中占4个字节。
4)无符号型:类型说明符为unsigned。
无符号又可与上述三种类型匹配而构成:
1)无符号基本型:类型说明符为unsigned int或unsigned.
2) 无符号短整型:类型说明符为unsigned short。
3)无符号长整型:类型说明符为unsigned long。
各种无符号类型量所占的内存空间字节数与相应的有符号类型数量相同。但由于省去了符号位,故不能表示负数。
3 整形变量的定义
变量定义的一般形式为:
类型说明符 变量名识别符,变量名标识符,…;
在书写变量定义时,应注意以下几点:
1)允许在一个类型说明符后,定义多个相同类型的变量。各变量之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。
2)最后一个变量名之后必须以“,”号结尾。
3)变量定义必须放在变量使用之前。一般放在函数体的开头部分。
4 整型数据的溢出
实型数据
1 实型常量的表示方法
实型也称为浮点型。实型常量也称为实数或者浮点数。在C语言中,实数只采用十进制。他有两种形式:十进制小数形式,指数形式。
1)十进制数形式:由数码0~9和小数点组成。
2)指数形式:由十进制数,加阶码标志“e"或”E"以及阶码(只能为整数,可以带符号)组成。
其一般形式为:
a E n(a为十进制数,n为十进制整数)
其值为a*10^n。
标准C允许浮点数使用后缀。后缀为“f”或“F”即表示该数为浮点数。如356f和356.是等价的。
2 实型变量
1 实型数据在内存中的存放形式
实型数据一般占4个字节(32位)内存空间。按指数形式存储。
小数部分占的位数愈多,数的有效数字愈多,精度愈高。
指数部分占的位数愈多,则能表示的数值范围愈大。
2 实型变量的分类
实型变量分为:单精度(float型)、双精度(double型)和长双精度(long double型)三类。
在turbo C中单精度型占4个字节(32位)内存空间,其数值范围为3.4E-38~3E+38,只能提供七位有效数字。双精度占8个字节(64位)内存空间,其数字范围位1.7E-308 ~1.7E+308,可提供16位有效数字。
实型变量定义的格式和书写规则与整型相同。
3 实型数据的舍入误差
由于实型变量是由有限的存储单元组成的,因此能提供的有效数字总是有限的。
3 实型常数的类型
实型常量不分单、双精度,都按双精度double型处理。
字符型数据
字符型数据包括字符常量和字符变量。
1 字符常量
字符常量使用单引号括起来的一个字符。
在C语言中,字符常量有以下特点:
1)字符常量只能用单引号括起来,不能用双引号或其他括号。
2)字符常量只能是单个字符,不能是字符串。
3)字符可以是字符集中任意字符。但数字被定义位字符型之后不能参与数值运算。
2 转义字符
转义字符是一种特殊的字符常量。转义字符以反斜线’“开头,后跟一个或几个字符。转义字符具有特定的含义,不同于字符原有的意义,故称“转意”字符。转义字符主要用来表示那些用一般字符不便于表示的控制代码。
广义得讲,C语言字符集中的任何一个字符均可用转义字符来表示。表中的\ddd和\xhh正是为此而提出的。ddd和hh分别为八进制和十六进制的ASCII代码。如\101表示字母“A”,\102表示字母"B”,\134表示反斜线,\XOA表示换行等。
3 字符变量
字符变量用来存储字符常量,即单个字符。
字符变量的类型说明符是char。字符变量类型定义的格式和书写规则都与整形变量相同。
4 字符数据在内存中的存储形式及使用方法
每个字符变量被分配一个字节的内存空间,因此只能存放一个字符。字符值是以ASCII码的形式存放在变量的内存单元之中的。
所以也可以把它们看成是整型量。C语言允许对整形变量赋以整型值。在输出时,允许把字符变量按整型量输出,也允许把整型量按字符量输出。
整型量为二字节量,字符量为单字节量,当整型量按字符型量处理时,只有低八位字节参与处理。
C语言允许字符变量参与数值运算,即用字符的ASCII码参与运算。
5 字符串常量
字符串常量是由一对双引号括起的字符序列。例如:“CHINA",“C program”,"$12.5"等都是合法的字符串常量。
字符串常量和字符常量是不同的量。它们之间主要有以下区别:
1)字符常量由单引号括起来,字符串常量由双引号括起来。
2)字符常量只能是单个字符,字符常量则可以含一个或多个字符。
3)可以把一个字符常量赋予字符串常量,的那不能把一个字符串赋予一个字符常量。在C语言中没有相应的字符串变量。这是与BASIC语言不同的。但是可以用一个字符数组来存放一个字符串常量。
4)字符串常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节数加1.增加的一个字节中存放字符”\0"(ASCII码为0)。这是字符串结束的标志。
变量赋初值
在程序中常常需要对变量赋初值,以便使用变量。语言程序中可有多种方法为变量提供初值。本小节先介绍在作变量定义的同时给变量赋以初值的方法。这种方法称为初始化。在变量定义中赋初值的一般形式为:
类型说明符 变量1=值1,变量2=值2,…;
应注意,在定义中不允许连续赋值,如a=b=c=5是不合法的。
各类数值型数据之间的混合运算
变量的数据类型是可以转换的。转换的方法有两种,一种是自动转换,一种是强制转换。自动转换发生在不同数据类型的两混合运算时,由编译系统自动完成。自动转换遵循以下规则:
1)软参与运算量的类型不同,则先转换成同一类型,然后进行运算。
2)转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。
3)所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也是要先转换成double型,再作运算。
4)char型和short型参与运算时,必须先转换成int型。
5)在赋值运算时,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
强制类型转换
强制类型转换是通过类型转换运算实现的。
其一般形式为:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
在使用强制转换时应注意以下问题:
1)类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2)无论时强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型。
算数运算符和算术表达式
C语言中运算符和表达式数量之多,在高级语言中时少见的。正是丰富的运算符和表达式使C语言功能十分完善。这也是C语言的主要特点之一。
C语言的运算符不仅具有不同的优先级,而且还有一个特点,就是它的结合性。在表达式中,各运算量参与运算的先后顺序不仅要遵循运算符优先级别的规定,还有受运算符结合性的制约,以便确定是自左向右进行运算还是自右向左进行运算。这种结合性是其他高级语言的运算符所没有的,因此也增加了C语言的复杂性。
1 C运算符简介
C语言的运算符可分为以下几类:
1 算术运算符:用于各类数值运算。包括加(+)、减(-)、乘()、除(/)、求余(或称模运算,%)、自增(++)、自减(–)、共七种。
2 关系运算符:用于比较运算。包括大于(>)、小于(<)、等于(==)、大于等于(>=)、小于等于(<=)、和不等于(!=)六种。
3 逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种。
4 位操作运算符:参与运算的量,按二进制位进行运算。包括位与(&)、位或(|)、位非(~)、位异或(^)、左移(<<)、右移(>>)六种。
5 赋值运算符:用于赋值运算,分为简单赋值(=)、复合算术赋值(+=,-=,^=,>>=,<<=)三种共十一种。
6 条件运算符:这是一个三目运算符,用于条件求值(?:)。
7 逗号运算符:用于把若干表达式组合成一个表达式(,)。
8 指针运算符:用于取内容()和取地址(&)二种运算。
9 求字节数运算符:用于计算数据类型所占的字节数(siaeof)。
10 特殊运算符:有括号(),下标 ,成员(),等几种。
2 算数运算符和算术表达式
1 基本的算数运算符
加法运算符“+”:加法运算符为双目运算符,即应有两个量参与加法运算。如a+b,4+8等。具有右结合性。
减法运算符“-”:减法运算符为双目运算符。但“-”也可作负号运算符,此时为单目运算符,如-x,-5等具有左结合性。
乘法运算符“*”:双目运算,具有左结合性。
除法运算符“/”:双目运算具有左结合性。参与运算量均为整型时,结果也为整型,舍去小数。如果运算量中有一个是实型,则结果为双精度实型。
求余运算符(模运算符)“%”:双目运算符,具有左结合性。要求参与运算的量均为整型。求余运算的结果等于两数相除后的余数。
2 算术表达式和运算符的优先级和结合性
表达式是由常量、变量、函数和运算符结合起来的式子。一个表达式有一个值及其类型,它们等于计算表达式所得结果的值和类型。表达式求值按运算符的优先级和结合性规定的顺序进行。单个的常量、变量、函数可以看作是表达式的特例。
算术表达式是由算术运算符和括号连接起来的式子。
算术表达式:用算术运算符和括号将运算对象(也称操作数)连接起来的、符号C语法规则的式子。
运算符的优先级:C语言中,运算符的运算优先级共分为15级。1级最高,15级最低。最表达式中,优先级较高的先于优先级较低的进行运算。而在一个运算量两侧的运算符优先级相同时,则按运算符的结合性所规定的结合方向处理。
运算符的结合性:C语言中各运算符的结合性分为两种,即左结合性(自左至右)和右结合性(自右至左)。例如算数运算符的结合性时自左至右,即先左后右。如有表达式x-y+z则y应为与“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左至右的结合方向就称为“左结合性”。而自右至左的结合方向称为“右结合性”。最典型的右结合性运算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。C语言运算符中有不少为右结合性,应注意区别,以避免理解错误。
3 强制类型转换运算符
其一般形式为:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
4 自增、自减运算符
自增1,自减1运算符:自增1运算符记为“++”,其功能是使变量的值自增1。
自减1运算符记为“–”,其功能是使变量值自减1。
自增1,自减1运算符均为单目运算,都具有右结合性。可有以下几种形式:
++i i自增1后再参与其它运算。
–i i自减1后再参与其它运算。
i++ i参与运算后,i的值再自增1。
i-- i参与运算后,i的值再自减1。
在理解和使用上容易出错的是i++和i–。特别是当它们出在较复杂的表达式或语句中时,常常难于弄清,因此应仔细分析。
赋值运算符和赋值表达式
1 赋值运算符
简单赋值运算符和表达式:简单赋值运算符记为“=”。由“=”连接的式子称为赋值表达式。其一般形式位:变量=表达式
赋值表达式的功能是计算表达式的值再赋予左边的变量。赋值运算符具有右结合性。因此
a=b=c=5可理解为a=(b=(c=5))
在其它高级语言中,赋值构成了一个语句,称为赋值语句。而在C中,把"=“定义为运算符,从而组成赋值表达式。凡是表达式可以出现的地方均可出现赋值表达式。
在C语言中也可以组成赋值语句,按照C语言规定,任何表达式在其末尾加上分号就构成为语句。
2 类型转换
如果赋值运算符两边的数据类型不相同,系统将自动进行类型转换,即把赋值号右边的类型换成左边的类型。具体规则如下:
1)实型赋予整形,舍去小数部分。
2)整型赋予实型,数值不变,但将以 浮点形式存放,即增加小数部分(小数部分的值为0)。
3)字符型赋予整型,由于字符为一个字节,而整型为二个字节,故将字符的ASCII码值放在整型量的低八位中,高八位为0.整形赋予字符型,只把低八位赋予字符量。
3 复合的赋值运算符
在赋值符”=“之前 加上其它二目运算符可构成复合运算符。如+=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。
构成复合赋值表达式的一般形式为:
变量 :双目运算符=表达式
它等效于
变量=变量 运算符 表达式
例如:a+=5 等价于a=a+5
逗号运算符和逗号表达式
在C语言中逗号“,”也是一种运算符,称为逗号运算符。其功能是把两个表达式连接起来组成一个表达式,称为逗号表达式。
其一般形式为:
表达式1,表达式2
其求值过程是分别求两个表达式的值,并以表达式2的值作为整个逗号表达式。
对于逗号表达式还要两点说明:
1)逗号表达式一般形式中的表达式1和表达式2也可以又是逗号表达式。
例如:表达式1,(表达式2,表达式3)
形成了嵌套情形。因此可以把逗号表达式扩展为以下形式:
表达式1,表达式2,…表达式n
整个逗号表达式的值等于表达式n的值。
2)程序中使用逗号表达式,通常是要分别求逗号表达式内各表达式的值,并不一定要求整个逗号表达式的值。
并不是在所有出现逗号的地方都组成逗号表达式,如在变量说明中,函数参数中逗号只是用做各变量之间的间隔符。