INT_MIN与溢出

隔了好久没更新了,由于我在学习PL和编译器/解释器的知识。

挺好奇这方面的,由于没有学过相关的课程。所以学起来有点吃力,进展缓慢。所以导致没啥可写的。


今天看到这么一段话:

32位的int型的取值是2147483647 到 -2147483648,可是。在C/C++语言中。你不能直接使用 -2147483648 来取代最小负数,由于它不是一个数。而是一个表达式。表达式是:“对正数2147483648取负”。所以,2147483648已经溢出了。这就是为什么INT_MIN总是定义成 (-INT_MAX - 1) 的原因。


之前没注意过这点。本着实践出真知的精神。我就在电脑上执行了下,发现结果是一样样的,用gcc开启Wall也没有不论什么警告。那么问题来了。到底是什么情况呢?

后来一位前MSRA的员工告诉我:

这个事实上要看标准的版本号吧……假设是C8(和谐)9。decimal literal的类型判断顺序是long, unsigned long,所以-21474836(和谐)48的literal会解释成unsigned long,所以取负就跪了;而假设是C++ 11。那判断顺序是long, long long就没啥问题

额,发现基础知识都遗忘了。

转载于:https://www.cnblogs.com/zhchoutai/p/7246754.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值