目录
前言
本文主要讲解点
- 关键字sizeof的理解
- 关键字signed\unsigned的理解
- 掌握原反补概念
- 深刻理解数据的取值范围
关键字-sizeof
- 定义
用来确定一种类型对应在开辟空间的时候的大小(对内置字符和自定义数组是可求的)
注:不要将sizeof误认为函数,虽然sizeof带有(),但是sizeof是操作符,关键字
- 示例
int a=10;
printf("%d\n", sizeof(a));
printf("%d\n", sizeof(int));
printf("%d\n", sizeof a);//这样写行不行? 可以
//得到的结果和sizeof(a)一致,说明sizeof并不是函数
printf("%d\n", sizeof int);//err 求类型大小必须带上()
- 与数组结合
int arr[3] = {1,2,3}
sizeof(arr) 结果为12(arr表示整个数组)
sizeof(arr+0)//或者sizeof(arr[0]) 结果为4(表示首元素地址)
//所有的地址大小为4(32位平台)/8(64位平台)
关键字-signed\unsigned
有符号数vs无符号数
char //字符数据类型
unsigned char //signed(有符号)/unsigned(无符号)
signed char
//大多数编译器默认char为 signed char 即有符号类型(有的认为是unsigned char)
//对于 short int long 都认为是有符号类型
short //短整型
unsigned short
signed short
int //整形
unsigned int
signed int
long //长整型
unsigned long
signed long
整形在内存的存储
变量的创建会在内存中开辟空间,而空间的大小根据类型来决定
原码、反码、补码
数据的表示有原码、反码和补码三种方法,均有符号位和数值位
符号位都是用0表示“正”,用1表示“负”(符号位依旧符合二进制运算)
- 有符号数
- 正整数
原、反、补码都相同
- 负整数
原码:直接将二进制按照正负数的形式翻译成二进制就可以
反码:将原码的符号位不变,其他位依次按位取反就可以得到了
补码:反码+1就得到补码
- 无符号数
不需要转化,也不需要符号位,原反补相同
- 对于整形来说
数据存放内存中其实存放的是补码
而数据的读取是使用原码
- 示例:
//字面值转补码
int a = 20;
//20是正整数
//原反补:0000 0000 0000 0000 0000 0000 0001 0100
int b = -10;
//-10是正整数
//原:1000 0000 0000 0000 0000 0000 0000 1010
//反:1111 1111 1111 1111 1111 1111 1111 0101
//补:1111 1111 1111 1111 1111 1111 1111 0110
//补码转源码
方法一:先-1,在符号位不变,按位取反
方法二:将原码到补码的过程在来一遍
十进制和二进制转换
口诀: 1 后面跟 n 个 0 ,就是 2 的 n 次方
大小端
CPU访存的基本单位是字节对于数据在内存存储补码时的字节排列顺序是有差异的(对于不同编译器)数据按照字节,是有高权值位低权值为之分的;内存按照字节是有高地址,低地址之别的
signed int b = -10;
//存:先转成补码
//原:1000 0000 0000 1010
//反:1111 1111 1111 0101
//补:1111 1111 1111 0110
unsigned int d = -10; //(是否合法?) 可以,存入与变量是否有符号无关
//存(补码):1111 1111 1111 0110
//存:字面数据必须先转成补码,在放入空间当中
//所以,所谓符号位,完全看数据本身是否携带+-号,和变量是否有符号无关!
//取:以什么样的形式读取(打印)例:%d(有符号整型打印)%u(无符号整形打印)
//取数据一定要先看读取类型,然后才决定要不要看最高符号位
//如果不需要,直接二进制转成十进制;如果需要,则需要转成原码,然后才能识别
//当然,最高符号位在哪里,又要明确大小端
整形取值范围
- 以char为例
unsigned char: [0,2^8-1]
signed char : [-2^7, 2^7-1] //char等价
特定数据类型,能表示的数据取值范围(范围由多个连续数据构成),本质是多位比特位形成的排列组合的的个数
- 如何理解-128
对于char类型来说(8bite)
0000 0000(表示0)(二进制转十进制)
0000 0001(表示1)
...
0111 1111(表示127)
1000 0001(表示-1)
...
1111 1111(表示-127)
but
1000 0000该表示什么?-0吗?计算机不会浪费任何一个空间
对于-128
原:1 1000 0000
反:1 0111 1111
补:1 1000 0000
存入时发生截断(存)补码:1000 0000
补码转原码时(发生截断):0000 0000
对于这种情况,1000 0000定义成为-128
这是一种半计算半定义的方式!
- 总结规律
整数的取值范围(n表示类型占用多少bite)无符号: [ 0 , 2 ^n - 1 ]有符号: [ - 2 ^ ( n - 1 ), 2 ^ ( n - 1 ) - 1 ]
第四章传送门:
⭐️ 关键字深度剖析 ⭐️第四章(分支和循环关键字)