《编写高质量代码:改善c程序代码的125个建议》——建议4-2:浮点数转换为新类型时必须做范围检查...
本節書摘來自華章計算機《編寫高質量代碼:改善c程序代碼的125個建議》一書中的第1章,建議4-2,作者:馬 偉 更多章節內容可以訪問云棲社區“華章計算機”公眾號查看。
建議4-2:浮點數轉換為新類型時必須做范圍檢查
關于浮點類型數據的轉換原則,在C99的6.3.1.4節與6.3.1.5節中做了非常重要的闡述,其表達的主要意思如下:
當我們將一個浮點類型的數據轉換成除_Bool類型之外的一個整型數據時,該浮點數的小數部分須被丟棄,只保留它的整數部分。如果浮點數整數部分的值無法使用這種整型表示方法時,其行為是未定義的。
與此同時,如果我們將一個整數類型的數據轉換成一個浮點類型時,如果該整型數據的值在該浮點數的取值范圍內,并且能夠被浮點類型精確表示,那么將會被正確轉換;如果該整型數據的值在該浮點數的取值范圍內,但不能夠被浮點類型精確表示,那么轉換的結果是最鄰近的稍大或者稍小的可表示值;但如果該整型數據的值在該浮點數的取值范圍外,其行為是未定義的。
當我們將一個double 類型降級轉換為float類型、將long double類型降級轉換到double或者float類型時,如果轉換的值在新類型的取值范圍內,并且能夠被新類型精確表示,那么將會被正確轉換;如果轉換的值在新類型的取值范圍內,但不能夠被新類型精確表示,那么轉換的結果是最鄰近的稍大或者稍小的可表示值;但如果轉換的值在新類型的取值范圍外,其行為是未定義的。
由此可見,為了避免浮點數據轉換時導致的未定義行為,我們應該在轉換時對數據進行相關的范圍檢查。例如,下面的代碼清單1-23演示了如何將double類型轉換為int類型。
在上面的程序中,我們通過語句“if(d1>(double)INT_MAX||d1<(double)INT_MIN)”來對程序做類型轉換時的取值范圍檢查,這樣就可以避免在執行語句“i1=(int)d1”時發生未定義行為。
但需要特別強調的是,上面的程序是建立在double類型的取值范圍大于int類型的取值范圍的基礎之上的。因此,在使用這種方法做取值范圍檢查時,你必須完全明白不同編譯器所對應的相關類型的取值范圍。假設在某個編譯器中,double類型的取值范圍小于int類型的取值范圍,那么上面這種方法將是不可行的,實際上這種情況基本沒有。
相對于浮點數與整數之間的轉換,浮點數與浮點數之間的轉換就簡單多了。演示示例如代碼清單1-24所示。
總結
以上是生活随笔為你收集整理的《编写高质量代码:改善c程序代码的125个建议》——建议4-2:浮点数转换为新类型时必须做范围检查...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 蓝桥杯算法提高 出现次数最多的
- 下一篇: find命令总结