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

            兔子的技術(shù)博客

            兔子

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            獲得程序或者一段代碼運(yùn)行的時(shí)間

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

              //獲取代碼結(jié)束時(shí)cpu內(nèi)部計(jì)數(shù)器的值,并減去初值
                    __asm
            {
              RDTSC
              mov HighEnd, edx
              Mov LowEnd,  eax
              ;獲取兩次計(jì)數(shù)器值得差
              sub eax,  LowStart
              cmp    eax,  0       ; 如果低32的差為負(fù)則求返,因?yàn)榈诙稳〉糜肋h(yuǎn)比第一次的大
              jg     L1
              neg     eax
              jmp     L2
                        L1: mov numlow,  eax
                        L2: sbb edx,  HighStart
              mov numhigh, edx
             
            }
                    //把兩個(gè)計(jì)數(shù)器值之差放在一個(gè)64位的整形變量中
                    //先把高32位左移32位放在64的整形變量中,然后再加上低32位
            __int64  timer =(numhigh<<32) + numlow;
                     //輸出代碼段運(yùn)行的時(shí)鐘周期數(shù)
                     //以頻率1.1Gcpu為例,如果換計(jì)算機(jī)把其中的1.1改乘其它即可,因?yàn)橄嘈糯蠹业腸pu都應(yīng)該在1G以上  ^_^
            cout<< (double) (timer /1.1/1000000000) << endl;
            return 0;
            }

                 這樣通過一條簡單的匯編指令就可以獲得程序或一段代碼的大概時(shí)間,不過并不能得到運(yùn)行的確切時(shí)間,因?yàn)榧词谷サ糁虚g的循環(huán),程序也會(huì)有個(gè)運(yùn)行時(shí)間,
            因?yàn)樵诘谝淮稳〉糜?jì)數(shù)器的值后,有兩條匯編指令mov HighStart, edx       mov LowStart, eax這兩條指令當(dāng)然也有運(yùn)行時(shí)間 ,當(dāng)然你可以減去這兩條指令的運(yùn)行時(shí)間(在1.1G的機(jī)子上是3e-8s),這樣會(huì)更精確一點(diǎn)。
                如果你要確切知道程序的運(yùn)行時(shí)間,專業(yè)的測試軟件肯定會(huì)更好一點(diǎn),不過好像一般沒有必要獲取除非專門的要求的程序。
                不過能DIY一個(gè)也是不錯(cuò)的,不管有沒有,最起碼你可以學(xué)到在VC++中如何嵌入?yún)R編代碼以及如何使用32位的寄存器,其實(shí)和16位的寄存器一樣使用,將來64的也應(yīng)該一樣,只不過位數(shù)不同罷了。
            posted on 2012-02-22 16:08 會(huì)飛的兔子 閱讀(1422) 評論(0)  編輯 收藏 引用 所屬分類: 系統(tǒng)API,底層技術(shù)
            国产综合精品久久亚洲| 久久久国产视频| 91精品国产高清久久久久久国产嫩草| 国产精品久久久久久久久鸭| 欧美性大战久久久久久| 久久午夜伦鲁片免费无码| 91麻精品国产91久久久久| 精品久久久中文字幕人妻| 精品久久久久久无码专区| 久久久久久国产a免费观看不卡| 伊人久久大香线蕉综合Av| 久久精品无码一区二区app| 9久久9久久精品| 久久婷婷激情综合色综合俺也去 | 99久久99久久精品国产| 久久人妻少妇嫩草AV蜜桃| 久久黄视频| 国产成人无码精品久久久久免费 | 久久不见久久见免费视频7| 久久精品中文字幕有码| 欧美日韩中文字幕久久伊人| 久久九九久精品国产免费直播| 日本久久久久久中文字幕| 久久久精品人妻一区二区三区蜜桃 | 国产精品99久久久精品无码| 大伊人青草狠狠久久| 久久久久亚洲AV无码网站| 9999国产精品欧美久久久久久| 99国产欧美久久久精品蜜芽| 精品国产VA久久久久久久冰| 久久精品人人槡人妻人人玩AV| 色综合久久综合中文综合网 | 久久精品国产一区二区三区日韩| 久久久久亚洲AV无码永不| 久久精品aⅴ无码中文字字幕重口| 亚洲乱码精品久久久久..| 久久香蕉超碰97国产精品| 久久国产热精品波多野结衣AV| 亚洲AV日韩精品久久久久| 久久精品亚洲一区二区三区浴池 | 麻豆成人久久精品二区三区免费 |