BlackWhite_idea 发表于 2021-11-26 19:02:17

用if判断数值是否超出int型的取值范围出益出

很纳闷
把max_int 赋值 pow(2,sizeof(int)*7)-1 即 max_int现在是2的28次方 的话 就肯可以判定的出、、
但是机子可以输出 2的31次方-1的值。。 就不知道为什么if判定不了、望大神看看

BlackWhite_idea 发表于 2021-11-26 19:07:01

还是说 当int j 和 int max_int一样大的时候 得用>= 才能识别得出来

傻眼貓咪 发表于 2021-11-26 19:45:52

本帖最后由 傻眼貓咪 于 2021-11-26 19:54 编辑

大哥,int 是正负值各占一半!
-32767 至 32767(2 bytes - 16 位系统)
-2147483648 至 2147483647(4 bytes)
而你的代码中,max_int = pow(2, 32) - 1 已经溢出(4294967296 - 1)
min_int 当然也是

BlackWhite_idea 发表于 2021-11-26 19:54:39

本帖最后由 BlackWhite_idea 于 2021-11-26 19:56 编辑

傻眼貓咪 发表于 2021-11-26 19:45
大哥,int 最大是 16 位,但是,正负值各占一半!-32767 至 32767
而你的代码中,max_int = pow(2, 32) -...

关键是我2的31次方也出问题。。

傻眼貓咪 发表于 2021-11-26 19:57:41

BlackWhite_idea 发表于 2021-11-26 19:54
我机子的int输出是4字节 32位。

还是溢出,因为正负值各占一半,除非你定义 unsigned(系统将全数记忆只用在储存正整数)

jhq999 发表于 2021-11-26 19:57:58

本帖最后由 jhq999 于 2021-11-26 20:02 编辑

傻眼貓咪 发表于 2021-11-26 19:45
大哥,int 是正负值各占一半!
-32767 至 32767(2 bytes - 16 位系统)
-2147483648 至 2147483647(4 b ...

[-2^31~2^31-1]32位-2147483648~2147483647
[-2^15~2^15-1]16位-32768~32767
零既不是正数也不是负数

傻眼貓咪 发表于 2021-11-26 19:58:52

BlackWhite_idea 发表于 2021-11-26 19:54
关键是我2的31次方也出问题。。

正负值各占一半容量这点很重要,否则代码容易出错(溢出)

傻眼貓咪 发表于 2021-11-26 20:02:13

jhq999 发表于 2021-11-26 19:57
[-2^31~2^31-1]32位-2147483648~2147483647
[-2^15~2^15-1]16位-32768~32767

已修改

BlackWhite_idea 发表于 2021-11-26 20:29:01

傻眼貓咪 发表于 2021-11-26 19:57
还是溢出,因为正负值各占一半,除非你定义 unsigned(系统将全数记忆只用在储存正整数)

懂了,谢谢解答
页: [1]
查看完整版本: 用if判断数值是否超出int型的取值范围出益出