一份自我复习笔记,欢迎大家 指正、补充
数据类型
int:整型变量,一般占4个字节(4B),范围为[-231,231-1] (4B共32位,其中此处为带 符号位1位)
unsigned int:无符号整型,占4个字节(4B),表示一个非负整数,范围为[0,232-1]
long:长整型,与int型一样,占4个字节(4B)
unsigned long:无符号长整型。类比int 和unsigned int。
short:短整型,表示一个整数,但占用2个字节(2B),范围为[-215,215-1](2B共16位,其中符号位占一位)
unsigned short:无符号短整型,占2个字节(2B),范围为[0,216-1]
char:字符型,表示一个字符,占1个字节如’a’和’0’等,**字符型变量存放的实际上是字符的ASCII码,例如’a’的ASCII码是97,即十六进制的0x61,则若:
char c='a';
则实际上变量c所指向的内存单元中存放着十六进制数0x61,或二进制数01100001
unsigned char: 无符号字符型,占1个字节(1B)
float:单精度浮点型,占4个字节(4B),表示一个浮点数(实数)
double:双精度浮点型,占8个字节(8B),精度比float高。
注:比较浮点型数据大小时,不能简单使用大于小于符号。
自动类型转换:等号右边类型T2与等号左边类型T1不符时,T2类型会转换为T1类型。
当然前提时两种类型是兼容的。
Example
int n1=1378;
char c='a';
c=n1;
在最后一句中,等号左边的char类型的变量,右边是int类型的变量,语句执行时,
1、先将右边的int值自动转换成一个char类型的值
2、再将该值赋值给c
但是由于char类型的变量只需要1字节,所以自动转换的过程就是丢弃n1的高三个字节,只取n1中最低的那个字节赋值给c
n1的值1378,十六进制表示是562,最低字节为0x62。故上述代码执行完以后c的值就是0x62,换成十进制的98。而98是字母’b’的ASCII值,故执行语句后,c中就存放着字母’b’。
这种转换并不会改变n1的值
在C/C++中,浮点数自动转换为整数的规则: 直接舍去小数部分