运行时错误除以-1
Runtime error dividing by -1
本文关键字:运行时错误 更新时间:2023-10-16
我不怀疑是否需要检查除以零。不过,我从来没有听说过用负数检查除法!
if( *y == 0 )
return 0; //undefined
else
return *x / *y;
x, y
是指向int32_t
的指针,我在相关的情况下包括了这个细节。
在运行时,如果*x==0x80000000, *y==0xffffffff
,我会得到错误(在Xcode中):
EXC_ARITHMETIC(代码=EXC_I386_DIV,子代码=0x0)
我在网上能找到的只是建议它被零除,但正如你从上面的检查中看到的,我也从调试窗口中看到的那样,这里的情况并非如此。
这个错误是什么意思?我该如何修复它?
2的补码表示是不对称的:负数比正数多出一个,而这个负数没有正数。因此,否定MIN_INT
是整数溢出(其中MIN_INT
是仅1位为符号位的值,对于32位整数为0x80000000)。
因此,MIN_INT / -1
也是一个算术溢出。与减法的溢出(很少检查)不同,除法时的溢出可能会导致陷阱,显然这就是您的情况。
是的,从技术上讲,在除法之前应该检查MIN_INT / -1
溢出情况,因为结果是未定义的。
注意:在英特尔x64体系结构的常见情况下,除法溢出会陷阱,与除以0完全相同。令人困惑的是,对应的Posix信号是SIGFPE
,通常被认为是"浮点异常",尽管看不到浮点。当前的Posix标准实际上将SIGFPE
解释为"错误算术运算"。
相关文章:
- 删除指向指针的指针是运行时错误吗
- c++中的指针和运行时错误
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 在同一模拟中使用静脉和静脉_ inet内容时出现运行时错误
- 对单向链表进行排序时出现运行时错误
- 为什么此代码存在运行时错误?
- 你能解释一下什么运行时错误是如何解决它的吗?
- 为什么会出现 gettnig 运行时错误:加载类型为"_Bit_type"(stl_bvector.h) 的空指针?
- 为什么程序在 c++ 中迭代 emtpy 向量时会抛出运行时错误
- 运行时错误:引用绑定到类型为"int"的空指针
- 为什么当 vector 为空时会显示运行时错误?
- C++运行时错误与快速排序算法抛出堆栈转储错误
- 运行时错误:矢量下标超出范围:正在检查空集
- 分配给gslice_array会导致运行时错误
- cout 新创建的对象引发运行时错误
- C++在使用std::multimap时出现运行时错误的几率很小
- 运行时错误:引用绑定到类型"int"的未对齐地址0xbebebebebebebec6,这需要 4 个字节对齐 (stl_vector.h)
- 试图找出为什么我会收到运行时错误?
- 迭代二维矢量时发生运行时错误
- 调用 java 的回调() 时应用程序崩溃.由于 detatchThread 而获得运行时错误