注册 登录
编程论坛 C语言论坛

c语言强制类型转化出现-2147483648

曼巴精神 发布于 2020-11-05 11:43, 2245 次点击
c语言强制类型转化出现-2147483648

float a=12345678912345.22;
int b=(int)a;
输出b就是-2147483648
5 回复
#2
rjsp2020-11-05 12:37
那你希望 (int)a 得到一个什么结果呢?

12345678912345 需要 44bits 的空间才能表达它。
#3
曼巴精神2020-11-05 18:54
回复 2楼 rjsp
就是在实际数据运算过程中,发现用比较大的数  取整后会发生这种情况,为什么是44bit啊


#4
rjsp2020-11-05 19:10
回复 3楼 曼巴精神
int 不可能无限大,肯定是有表达范围的呀。
(另外,对于 具符号整型 而言,溢出 是 未定义行为)

因为 2的43次方 < 12345678912345 <= 2的44次方,
所以 12345678912345 至少需要一个 44bits 有效位的类型。
#5
曼巴精神2020-11-05 20:20
回复 4楼 rjsp
好的多谢
#6
角动量2020-11-08 00:08
版主以回复正确地结果
1