char类型能赋最小值-128,而int类型不能直接赋最小值-2147483648

在此,仅谈谈自己的理解,如有错误,欢迎指正!谢谢!

在64位系统中,类型字节大小<4字节,按4字节对整型常数进行处理,因此
(1)对取值范围为[-128,128)的char类型赋最小值-128,处理如下
128  .  0x00 00 00 10 (原码 ,反码 ,补码)
采用一元负运算符“-”对其取反,操作为取反加1(~(128)+1)
128 取反为 0xFF FF FF 7F,加1为 0xFF FF FF 10

char类型取低字节 0x10 (补码)存放,显示时采用printf

char c = -128;//0x10
printf("%c\n",c);

printf函数按从右到左进行入栈操作,每次入栈4字节,若入栈元素为char或short等小于4个字节的类型,入栈时也占4字节。因此0x10实际入栈为 0xFF FF FF 10 (补码),这里按符号位进行了补全,按char类型截取低字节对照ASCII表显示相应符号,若按照int类型显示,则显示

0xFF FF FF 10 (补码)对应的原码 0x10 00 00 10 (原码),-128

printf("%d\n",c);//-128
(2)对取值范围为[-2147483648,2147483648)的int类型赋最小值-2147483648,处理如下
2147483648  ,0x10 00 00 00 (原码 ,反码 ,补码)
由于int类型最大值为2147483647,因此当整型常量大于此值,将其类型优化为unsigned int (即取消符号位)
同样采用一元负运算符“-”对其取反,操作为取反加1
2147483648 取反仍为  0x10 00 00 00
因此产生了错误“一元负运算符应用于无符号类型,结果仍为无符号类型”

因为不报错会产生如下情况

int a = -2147483648;//实际上值为2147483648
if(5 > a){//按赋值意图将,5大于a,此处为true,但实际情况是5 < a,此处为false
	...;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值