C语言由位数截取的原因所引发的错误

在聊二进制的位数截取之前呢我们需要先了解两个知识点,一是数字类型的不同所占的存储空间是不同的,进而导致每个数据类型所能存储的数据范围不同。二是编译过程中计算机原码,反码,补码的转换。

一、常见数据类型的存储空间

1.整数类型

1.1char:占用的内存空间:1字节 8bit;

能存储的数据范围:无符号:[0, 2^8-1],有符号:[-2^7, 2^7-1]

1.2short:占用的内存空间:2字节 16bit;

能存储的数据范围:无符号:[0, 2^16-1],有符号:[-2^15, 2^15-1]

1.3.int:占用的内存空间:4字节 32bit

能存储的数据范围:无符号:[0, 2^32-1],有符号:[-2^31, 2^31-1]

1.4.long:占用的内存空间:8字节 64bit

能存储的数据范围:无符号:[0, 2^64-1],有符号:[-2^63, 2^63-1]

2.浮点类型

浮点型存储涉及到小数的二进制,取得大部分都是近似值,本次不讨论。

3.空类型

 void 叫做空类型,不占用内存空间,一般搭配指针使用,后续再说指针。

 二、原码、反码、补码转换的问题。

1.转化的规则

无符号数:原码、反码、补码 都是一样的

有符号的正数:原码、反码、补码 都是一样的

有符号的负数:反码==原码中符号位不变,其他位按位取反 0变成1 1变成0

2.存储时的不同

存储时看数据(正负),取出时看类型(有无符号)

 三、实例演示

了解完这些问题,咱们通过一些例子去验证一下。

1.正常情况

int main(int argc, const char *argv[])
{
	unsigned char a = 10;
	//存储时
	//原码: 0000 1010
	//反码: 0000 1010
	//补码: 0000 1010
	//取出时
	//补码: 0000 1010
	//反码: 0000 1010
	//原码: 0000 1010 -->10
	printf("a = %d\n", a);//10

	signed char b = -10;
	//存储时
	//原码: 1000 1010
	//反码: 1111 0101
	//补码: 1111 0110
	//取出时
	//补码: 1111 0110
	//反码: 1111 0101
	//原码: 1000 1010 --> -10
	printf("b = %d\n", b);//-10

2.错误情况

	signed char c = 129;
	//存储时
	//原码: 1000 0001
	//反码: 1000 0001
	//补码: 1000 0001
	//取出时
	//补码: 1000 0001
	//反码: 1000 0000
	//原码: 1111 1111 --> -127
	printf("c = %d\n", c);// -127

	unsigned char d = -1;
	//存储时
	//原码: 1000 0001
	//反码: 1111 1110
	//补码: 1111 1111
	//取出时
	//补码: 1111 1111
	//反码: 1111 1111
	//原码: 1111 1111 -->255
	printf("d = %d\n", d);//255

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值