• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 51, 文章 - 1, 評論 - 41, 引用 - 0
            數據加載中……

            float型數據小議

                     前些日子在使用Kinsol庫(求解非線性方程的數值庫)時,出現死循環。調試跟蹤,發現浮點型數據異常,異常的數據使得大小比較失效,無法退出循環。這個問題涉及到浮點型數據的具體構造,詳細介紹可參考下文:http://steve.hollasch.net/cgindex/coding/ieeefloat.html

                     本文討論怎樣的運算造成異常的浮點型數據,即異常數據的來源。浮點型數據分成三類,finite型,inf型,nan型。finite型好理解,是指有限數如0,1.1等。inf型是表示無窮大數,分為正無窮和負無窮,它由非0的有限數除0得到或者超過了浮點型能夠表示的最大最小數。浮點型不像整型那樣除零報錯。nan型即not a number, 表示這不是一個數。它是由一些無意義的運算引起的,比如0/0,inf-inf,inf*0等,這些運算不能確定結果是什么。

                     前兩種類型是可以比較大小,比如:1<inf,inf > 3,inf > -inf,inf == inf。這些比較是有意義的。但不能和nan型比較,如果比較則總返回0(返回什么值,大家最好自己做測試),我遇到的問題就是在比較表達式中出現了nan型數。

                     要判斷一個浮點數是否是inf或者nan,有函數int _isnan(double x)int _finite(double x),在float.h中聲明。

            posted on 2008-05-17 18:24 lemene 閱讀(1177) 評論(0)  編輯 收藏 引用

            91精品国产综合久久精品| 狠狠色丁香婷综合久久| 久久亚洲国产最新网站| 久久国产欧美日韩精品| 国产精品久久亚洲不卡动漫| 久久夜色精品国产亚洲| 日韩美女18网站久久精品| 亚洲国产精品无码久久SM| 久久精品国产亚洲一区二区| 综合久久久久久中文字幕亚洲国产国产综合一区首| 欧美久久亚洲精品| 韩国三级大全久久网站| 一本久道久久综合狠狠躁AV| 国产精品久久精品| 精品久久久久久中文字幕大豆网| 91亚洲国产成人久久精品网址| 亚洲αv久久久噜噜噜噜噜| 久久久久婷婷| 99久久国产亚洲高清观看2024| 久久天天躁狠狠躁夜夜avapp | 久久亚洲日韩看片无码| 91精品国产综合久久香蕉 | 久久国产精品-国产精品| 久久亚洲熟女cc98cm| 无码8090精品久久一区| 精品人妻伦九区久久AAA片69| 久久99精品久久久久久久不卡| 奇米影视7777久久精品人人爽| 人人狠狠综合久久亚洲高清| 久久国产热这里只有精品| 91精品国产高清久久久久久国产嫩草 | 国产精品久久久久AV福利动漫| 亚洲欧美日韩久久精品第一区| 亚洲日韩欧美一区久久久久我| 国内精品久久久久久久影视麻豆 | 亚洲国产天堂久久综合| 色综合合久久天天给综看| 久久中文字幕视频、最近更新| 久久99久久成人免费播放| 日日狠狠久久偷偷色综合96蜜桃| 精品久久综合1区2区3区激情|