变量的本质:一段连续内存空间的别名
Int a 告诉C编译器给我分配四个字节的内存。
1、数据类型的本质:可理解为创建变量的模具,是固定大小内存的别名。
2、数据类型的作用:
3、求数据类型大小:sizeof()
注意:sizeof()是操作符(单目运算符),不是函数。Sizeof测量的实体大小在编译期间就已经确定,sizeof操作符以字节形式给出了其操作数的存储大小。
sizeof操作符的结果类型是size_t,它在头文件<stddef.h>中typedef为unsigned int类型。该类型保证能容纳实现所建立的最大对象的字节大小。
4、数据类型可以有别名
typedef uu int;
sizeof(uu)=sizeof(int);
1.不同数据类型之间运算会进行自动类型转换:由低转高
2.强制类型转换
一般形式:(类型名)(表达式)
例 (int)(x + y)
(int)x + y
(double)(3/2)
(int)3.6
说明:强制转换得到所需类型的中间变量,原变量类型、变量值保持不变 。
较高类型向较低类型转换时可能发生精度损失问题。
3.类型间转换
(1)格式输出
例如
int a = 2147483648;
printf("%d",a);
这样赋值后,输出变量a的值并非预期的2147483648,而是-2147483648,原因是2147483648超出了int类型能够装载最大值,数据产生了溢出。如果换一种输出格式控制符,代码如下所示:
printf("%u",a);
输出的结果就是变量a的值,原因是%u是按照无符号整型输出的数据,而无符号整型的数据范围上限大于2147483648这个值。
(2)当把占字节较小的数据赋值给占字节较大的数据时,可能出现以下两种情况:
第1种情况,当字节较大数是无符号数时,转换时新扩充的位被填充成0
char b = 10;
unsigned short a = b;
printf("%u",a);
这样赋值后,变量a中输出的值是10。
第二种情况,当字节较大数是有符号数时,转换时新扩充的位被填充成符号位。
char b = 255;
short a = b;
printf("%d",a);
这样赋值后,变量a输出的值是-1,变量a扩充的高8位,根据变量b的最高位1都被填充成了1,所以数值由正数变成了负数,因为变量a的最高位符号位是1,至于为什么16个1表示的是-1,涉及到二进制数的原码和补码问题