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

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            獲得程序或者一段代碼運行的時間

             (2006-06-14 09:49:11)
            如何獲得程序或者一段代碼運行的時間?你可能說有專門的程序測試工具,確實,不過你也可以在程序中嵌入匯編代碼來實現。
                 在Pentium的指令系統中有一條指令可以獲得CPU內部64位計數器的值,我們可以通過代碼兩次獲取該計數器的值而獲得程序或代碼運行的時鐘周期數,進而通過你的cpu的頻率算出一個時鐘周期的時間,從而算出程序運行的確切時間。
                我們通過指令TDSIC來獲得cpu內部計數器的值,指令TDSIC返回值放在EDX:EAX中,其中EDX中存放64位寄存器中高32位的值,EAX存放第32位的值.
                下面看看實現的代碼:
             
            //用匯編實現獲取一段代碼運行的時間
            #include<iostream>
            using namespace std;
            void GetClockNumber (long high, long low);
            void GetRunTime();
            int main()
                 
            long HighStart,LowStart,HighEnd,LowEnd;
            long numhigh,numlow;
            //獲取代碼運行開始時cpu內部計數器的值
            __asm             
            {
              RDTSC
              mov HighStart, edx
              mov LowStart, eax
            }
            for(int i= 0; i<100000; i++ )
            {
                         for(int i= 0; i<100000; i++ )
                  {
                  
                  }
            }
             
             
             

              //獲取代碼結束時cpu內部計數器的值,并減去初值
                    __asm
            {
              RDTSC
              mov HighEnd, edx
              Mov LowEnd,  eax
              ;獲取兩次計數器值得差
              sub eax,  LowStart
              cmp    eax,  0       ; 如果低32的差為負則求返,因為第二次取得永遠比第一次的大
              jg     L1
              neg     eax
              jmp     L2
                        L1: mov numlow,  eax
                        L2: sbb edx,  HighStart
              mov numhigh, edx
             
            }
                    //把兩個計數器值之差放在一個64位的整形變量中
                    //先把高32位左移32位放在64的整形變量中,然后再加上低32位
            __int64  timer =(numhigh<<32) + numlow;
                     //輸出代碼段運行的時鐘周期數
                     //以頻率1.1Gcpu為例,如果換計算機把其中的1.1改乘其它即可,因為相信大家的cpu都應該在1G以上  ^_^
            cout<< (double) (timer /1.1/1000000000) << endl;
            return 0;
            }

                 這樣通過一條簡單的匯編指令就可以獲得程序或一段代碼的大概時間,不過并不能得到運行的確切時間,因為即使去掉中間的循環,程序也會有個運行時間,
            因為在第一次取得計數器的值后,有兩條匯編指令mov HighStart, edx       mov LowStart, eax這兩條指令當然也有運行時間 ,當然你可以減去這兩條指令的運行時間(在1.1G的機子上是3e-8s),這樣會更精確一點。
                如果你要確切知道程序的運行時間,專業的測試軟件肯定會更好一點,不過好像一般沒有必要獲取除非專門的要求的程序。
                不過能DIY一個也是不錯的,不管有沒有,最起碼你可以學到在VC++中如何嵌入匯編代碼以及如何使用32位的寄存器,其實和16位的寄存器一樣使用,將來64的也應該一樣,只不過位數不同罷了。
            posted on 2012-02-22 16:08 會飛的兔子 閱讀(1401) 評論(0)  編輯 收藏 引用 所屬分類: 系統API,底層技術
            久久久久亚洲Av无码专| 久久久久国产精品嫩草影院| 久久精品国产亚洲AV无码娇色| 日产精品99久久久久久| 日韩一区二区久久久久久| 国产成人99久久亚洲综合精品 | 久久久久亚洲精品中文字幕| 2021久久精品免费观看| 国产精品一区二区久久不卡| 久久午夜无码鲁丝片午夜精品| 亚洲精品无码久久久影院相关影片 | 国产精品99久久久精品无码| 久久国产精品-久久精品| 亚洲国产成人精品女人久久久 | 国产精品99久久久久久猫咪| 国产精品久久久久蜜芽| 国产真实乱对白精彩久久| 99久久夜色精品国产网站| 99久久综合狠狠综合久久| 亚洲AV无码一区东京热久久| 伊人久久大香线蕉无码麻豆| 狠色狠色狠狠色综合久久| 日韩精品久久久久久久电影蜜臀| 久久久久亚洲精品无码网址| 国产叼嘿久久精品久久| 国产情侣久久久久aⅴ免费| 2021最新久久久视精品爱| 久久精品免费大片国产大片| 亚洲天堂久久精品| 久久青青草原综合伊人| 国产99精品久久| 亚洲精品午夜国产VA久久成人| 国产精品美女久久福利网站| 亚洲美日韩Av中文字幕无码久久久妻妇| 99久久精品费精品国产| 久久99热只有频精品8| 久久无码人妻一区二区三区| 亚洲狠狠婷婷综合久久蜜芽| 囯产精品久久久久久久久蜜桃| 欧美一区二区久久精品| 久久久亚洲AV波多野结衣|