c++ 出现1.#IND、1.#INF
?1.#INF / inf:這個值表示“無窮大 (infinity 的縮寫)”,即超出了計算機可以表示的浮點數的最大范圍(或者說超過了 double 類型的最大值)。例如,當用 0 除一個整數時便會得到一個1.#INF / inf值;相應的,如果用 0 除一個負整數也會得到 -1.#INF / -inf 值。
2.-1.#IND / nan:這個的情況更復雜,一般來說,它們來自于任何未定義結果(非法)的浮點數運算。"IND"是 indeterminate 的縮寫,而"nan"是 not a number 的縮寫。產生這個值的常見例子有:對負數開平方,對負數取對數,0.0/0.0,0.0*∞, ∞/∞ 等。
簡而言之,如果遇到 1.#INF / inf,就檢查是否發生了運算結果溢出除零,而遇到 1.#IND / nan,就檢查是否發生了非法的運算。
?
如果出現1.#INF的情況,說明程序中做除法時發生了除0。那程序編譯怎么能通過呢?
原來除數為0有兩種情況。
?
(1)除數顯式為0,無論是整型還是浮點型都不能通過編譯。
?? 如:cout<< 2/0<<endl;
?會顯示: 錯誤?1?error C2124: 被零除或對零求模?
?
(2)除數隱式為0,無論是整型還是浮點型都能通過編譯,但整型將報錯且其后程序不再執行。浮點型執行得到正無窮大或負無窮大,依被除數而定,且其后程序正常執行。
?? 如:int i=0;cout<< 2/i<<endl;
????? testexe 中的 0x000000013f2112cb 處有未經處理的異常: 0xC0000094: Integer division by zero
? 而?
????? float i=0.0;? ?cout<< 2/i<<endl; 這樣程序就不會報錯,并且繼續執行。
?
??????二者的區別是由在計算機中儲存不同類型的數據方法的不同決定的。
?
總結
以上是生活随笔為你收集整理的c++ 出现1.#IND、1.#INF的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: c++连接mongodb出错
- 下一篇: 计算灰度共生矩阵相关性时sigmax,y