小编典典
请检查 http://linux.die.net/man/1/gcc中
有一个编译器选项-mcheck-zero-division来处理。
另外,也可以选择安装SIGFPE处理程序,然后将float div乘以0将生成一个’FPE_ZERODIVIDE’
signal(SIGFPE, (fptr) FPE_ExceptionHandler);
void FPE_ExceptionHandler(int nSig,int nErrType,int */*pnReglist*/)
{
switch(nErrType)
{
case FPE_ZERODIVIDE: /* ??? */ break;
}
}
以来
大多数浮点系统基于IEEE标准,该标准允许除以0。这会根据数字的符号适当地返回正无穷大或负无穷大。(除了0/0之外,返回的是未定义的NAN,这同样不是例外情况。)这对于科学和数学应用来说往往很有用。NAN有效地表明了一种情况,即无法进行计算但可以继续进行计算。继续的计算不会产生新的结果,但是会继续返回NAN。这允许在计算过程中执行长而长的计算链,而无需进行错误检查。错误检查仅需要在工作的最后完成。这使代码更简单,也更快。有时对于某些应用程序,它也可能更有用,
2020-06-07