• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            C++中獲取高精度時間差

            Posted on 2011-03-31 17:16 S.l.e!ep.¢% 閱讀(384) 評論(0)  編輯 收藏 引用 所屬分類: Unix

            C++中獲取高精度時間差
            2011-01-30 00:00出處:中國IT實驗室作者:佚名【我要評論】 [導讀]解決一個問題通常有多種方法, 我們總想找到最高效的,所以需要對比不同算法執行所用的時間。可惜的是,C++中提供的方法一般只能精確到毫秒級。
             企業軟件熱點文章?
             攻擊Linux服務 器的四種級別  在Windows中如 何取舍嵌套處理

              解決一個問題通常有多種方法, 我們總想找到最高效的,所以需要對比不同算法執行所用的時間。可惜的是,C++中提供的方法一般只能精確到毫秒級。

              提供一種更加精確的方法。編寫一個函數,可以在C++中這樣寫:

              __declspec (naked) unsigned __int64 GetCpuCycle( void )

              {

              _asm

              {

              rdtsc

              ret

              }

              }

              RDTSC的返回值存放在EDX EAX中, EDX為高32位,EAX為低32位。這里的 RDTSC 指令( Read Time Stamp Counter ), 獲得CPU的高精度時間戳。

              這樣以來我們就可以在隨處獲得當前的CPU自上電以來的時間周期數了:

              unsigned __int64 iCpuCycle = GetCpuCycle();

              根據這個數字我們可以計算出上電以來所經歷的時間( 秒s ):

              second = iCpuCycle / CPU主頻率( HZ );

              1GHZ = 1,000 MHZ = 1,000,000 KHZ = 1,000,000,000 HZ;

              獲取兩次作差就可以得到運行的時間了。其實沒必要換算成時間,關注差值就行了。

              PS:

              可以放心一個unsigned __int64 不會溢出 - - 可以計算一下你的CPU能保存多少年的時間。。

              根據這一方法有幾個好處: 一是精度高,二是函數調用開銷最小,三是平臺限制小,四是具有和CPU主頻相對應的直接關系。。。 但是由于精度高,得到的數字浮動比較大。。

            原文出自【比特網】,轉載請保留原文鏈接:http://soft.chinabyte.com/database/62/11805062.shtml

            无码人妻精品一区二区三区久久| 久久精品国产精品亚洲艾草网美妙| 久久这里只有精品首页| 亚洲AV无码久久精品色欲 | 国产精品欧美亚洲韩国日本久久| 久久99精品国产麻豆婷婷| 伊人久久大香线蕉成人| 亚洲va国产va天堂va久久| 国产精品久久久天天影视香蕉| 久久午夜无码鲁丝片秋霞| 久久精品国产亚洲AV香蕉| 欧美亚洲日本久久精品| 999久久久免费精品国产| 亚洲日本久久久午夜精品| 9191精品国产免费久久| 亚洲AV无码久久精品成人| 久久精品国产一区二区电影| 久久精品国产久精国产一老狼| 久久精品国产99国产精品澳门| 久久婷婷五月综合色奶水99啪| 丁香久久婷婷国产午夜视频| 久久久99精品一区二区| 久久噜噜电影你懂的| 精品久久久久久久久午夜福利| 亚洲精品第一综合99久久| 久久国产成人亚洲精品影院| 91精品国产乱码久久久久久| 久久久久久精品免费看SSS| 久久精品国产亚洲Aⅴ香蕉| 久久被窝电影亚洲爽爽爽| 77777亚洲午夜久久多喷| 亚洲精品无码专区久久久| 思思久久好好热精品国产| 久久久久亚洲精品无码网址 | 99精品久久久久久久婷婷| 国产亚洲精品自在久久| 狠狠色丁香久久婷婷综合五月| 午夜精品久久久久久毛片| 亚洲av日韩精品久久久久久a| 日韩精品久久久久久久电影| 亚洲国产视频久久|