int main()
{
int m;
m=1/0;
printf("%d",m);
return 0;
}
int main()
{
double m;
m=1.0/0.0;
printf("%lf",m);
return 0;
}
特殊浮點數的含義
1.#INF / inf:這個值表示“無窮大 (infinity 的縮寫)”,即超出了計算機可以表示的浮點數的最大范圍(或者說超過了 double 類型的最大值)。
例如,當用 0 除一個整數時便會得到一個1.#INF / inf值;相應的,如果用 0 除一個負整數也會得到 -1.#INF / -inf 值。 -1.#IND / nan:這個的情況更復雜,一般來說,它們來自于任何未定義結果(非法)的浮點數運算。"IND"是 indeterminate 的縮寫,而"nan"是 not a number 的縮寫。產生這個值的常見例子有:對負數開平方,對負數取對數,0.0/0.0,0.0*∞, ∞/∞ 等。 簡而言之,如果遇到 1.#INF / inf,就檢查是否發生了運算結果溢出除零,而遇到 1.#IND / nan,就檢查是否發生了非法的運算。
特殊浮點數的判斷
很多 C 庫都提供了一組函數用來判斷一個浮點數是否是無窮大或 NaN。int _isnan(double x) 函數用來判斷一個浮點數是否是 NaN,而 int _finite(double x) 用以判斷一個浮點數是否是無窮大。
你可能已經注意到了,上面兩個函數都是以下劃線開頭的,因此在可移植性上可能是存在問題的,那么如何實現一個通用的判斷版本呢?
首先,對于 Nan,可以用下面的代碼實現:
新聞熱點
疑難解答
圖片精選