文章目录
一、字符数据类型介绍
char //字符数据类型 1个字节
short //短整型 2个字节
int //整形 4个字节
long //长整型 4个字节
long long //更长的整形 8个字节
float //单精度浮点数 4个字节
double //双精度浮点数 8个字节
二、整形家族
char //(取决于编译器,常见编译器下相当于signed char)
unsigned char
signed char
short //(相当于signed short [int])
unsigned short [int]
signed short [int]
int //(相当于signed int)
unsigned int
signed int
long //(相当于signed long [int])
unsigned long [int]
signed long [int]
// []表示可省略部分
注:
char类型为何会在整型里呢?
这是因为在内存中字符类型以ASCII码值来存储:
三、为什么计算机里存储补码呢?
在计算机系统中,数值一律用补码来表示和存储。原因在于,使用补码,可以将符号位和数值域统一处理;
同时,加法和减法也可以统一处理(CPU只有加法器1-1 相当于1+(-1))
此外,补码与原码相互转换,其运算过程是相同的(都可以通过取反加一实现),不需要额外的硬件电路。
四、大小端介绍
大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;
小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地址中。
例题:
设计一段代码,判断当前机器的字节序。
int check_sys()
{
int i = 1;
return (*(char *)&i);
}
int main()
{
int ret = check_sys();
if(ret == 1)
{
printf("小端\n");
}
else
{
printf("大端\n");
}
return 0; }
五、char类型易错点分析
5.1 char类型的特殊用法
我们在学习过程中经常会发现,例如如下的代码:
char a = 100;
这时我们不禁会想到为什么char类型可以存放整型100呢?
解:
其实,计算机存储整数,在内存中是以整数对应二进制的补码来存储的。
对于int类型来说,一旦创建变量,就会在内存开辟4个字节大小的空间,也就是32bit的大小,每个比特位都会存放0或者1。
而对于char类型来说,一旦创建变量,就会在内存中开辟1个字节的空间,也就是8bit的大小。
所以上述代码的内部原理,char类型会将100对应的二进制的补码的最低8位截取存在变量a中。
5.2 char类型的变量中到底能放什么数值?
不管是signed char还是unsigned char类型,在内存中均以整数对应二进制的补码,8个bit位存储。
5.2.1 unsigned char类型取值范围
对于无符号类型,8个bit位都是有效位,且每位数对应二进制的原反补相同,所以将上述二进制全部转为十进制即取值范围:0 ~ 255
5.2.2 signed char类型取值范围
对于有符号类型,第一位都是符号位,后7位是有效位,所以正负分别来探讨:
- 对于符号位为0的正数,对应二进制的原反补相同,得取值范围:0 ~ 127
- 对于符号位为1的负数,对应二进制的原反补不同,需要将内存中的补码对应的原码求出,再化为十进制,得取值范围:-1 ~ -128
10000000对于有符号数,我们规定化为其对应二进制的原码,转化为十进制是128
综上:signed char类型取值范围:-128 ~ 127
注:
实际对于signed char类型,11111111加一为00000000,01111111加一为10000000,所以其实为一个圆形循环。
即理解为:对于char类型能存放的十进制数值,-1加一为0,127加一为-128。