在VC++通过汇编实现获取代码运行时间

原创 2004年06月13日 16:10:00

                         在VC++通过汇编实现获取代码运行时间

     如何获得程序或者一段代码运行的时间?你可能说有专门的程序测试工具,确实,不过你也可以在程序中嵌入汇编代码来实现。
     在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
  //--------------------------------------------------------
  //以前代码有逻辑错误,其实直接用sbb减就可以了,而不必考虑低32位是否高于高32
  RDTSC
  mov HighEnd, edx
  Mov LowEnd,  eax
  sub eax, LowStart
  mov     numlow,  eax
  mov     eax,edx
  sbb     eax,HighStart 
  mov     numhigh,eax

 }
        //把两个计数器值之差放在一个64位的整形变量中
        //先把高32位左移32位放在64的整形变量中,然后再加上低32位
         __int64  timer =0;

        timer |= numhigh;
        timer = timer<<32;
        timer |= 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的也应该一样,只不过位数不同罢了。
^_^

-----------------------------------------------------------------------------------------------
     发现程序有错误cry_smile.gif当第一次取得计数器的值为 0xFFFFFFFF时,第二次取0x00000000最后输出的值肯定是负值。对于某个cpu来说,可以计时的最大时间为0xFFFFFFFF/cpu频率(单位为G)/1000000000s。
     所以只能用来计算运行时间小于最大时间的代码才可能是正确的(也有可能是错误的sad_smile.gif)。
另外,如果是双cpu的话,会出现什么问题???如何才能解决上面提到的问题??
思考中……

感谢 IPLinger 提出程序中的问题,及提出自己的想法,才使我发现了其中的错误,在此表示感谢!
                                                                                                                       
                                                                                                                             2004年11月10日

 

VC实例分析:VC++通过汇编获取代码运行时间

如何获得程序或者一段代码运行的时间?你可能说有专门的程序测试工具,确实,不过你也可以在程序中嵌入汇编代码来实现。   在Pentium的指令系统中有一条指令可以获得CPU内部64位计数器的值,我们可以...
  • iiprogram
  • iiprogram
  • 2007年10月06日 22:44
  • 885

VC++如何获取代码运行时间

如何获取代码运行时间 在调试中,经常需要计算某一段代码的执行时间,下面给出两种常用的方式: 第一种:使用GetTickCount函数 #include #include ...
  • zjd1023
  • zjd1023
  • 2011年05月01日 00:19
  • 1837

Android获取App启动时间

调用Android隐藏API的方法目前一共有三总,Java反射、API欺骗、修改源码重新编译...
  • yutou58nian
  • yutou58nian
  • 2014年03月16日 18:19
  • 3337

VC/MFC中计算程序运行时间

原文链接点击打开链接 方法一 利用GetTickCount函数(ms) 代码: CString str;             long t1=GetTickCount...
  • MayDayLast
  • MayDayLast
  • 2014年03月11日 09:25
  • 1622

VC++追踪代码运行时间

为了方便调试,自己编写了一个探测代码运行时间的类。 该类能够实现us级的精确延时,对于一般的算法应用(ms级别)足够了。 主要用到windows的API,以下是代码: DetectTim...
  • Kelvin_Yan
  • Kelvin_Yan
  • 2014年12月07日 15:54
  • 591

查看代码运行时间

有时候我们想要准确的知道某段代码、某个循环执行的时间,然后分析效率等问题,这个时候就需要执行时间是多少。正好看到网上已经有人做了这个工作,我就直接摘下来了。正好也用了宏的方式计算时间,我们只要在需要计...
  • u012701023
  • u012701023
  • 2016年03月22日 11:04
  • 820

如何计算一段代码的运行时间

1.用指令周期,51系列单片机指令周期是晶振周期的12倍,比如12M晶振,指令周期是1us,每条指令的指令周期是不一样的。或者不嫌麻烦的话可以去数指令。注意:现在的很多MCU是多级流水线,其实这样计算...
  • tangxing1212
  • tangxing1212
  • 2015年11月07日 11:22
  • 1653

VC++如何计算一段代码的执行时间

单位为毫秒
  • u013035197
  • u013035197
  • 2014年02月21日 11:34
  • 1011

如何在VC6.0中得到一个程序的运行时间,也就是这个程序耗费的时钟周期数// C和C++的时间编程

#include     #include     using   namespace   std;     int   main()     {     time_t   begin,end;   ...
  • zhongrg
  • zhongrg
  • 2007年11月18日 16:22
  • 5364

VC++代码注入,实现对Tutorial的外挂控制

代码注入3种方式: Ⅰ. Windows 钩子 Ⅱ. CreateRemoteThread 和 LoadLibrary 技术 Ⅲ.CreateRemoteThread和WriteProcessMe...
  • ldxicare
  • ldxicare
  • 2015年04月09日 08:36
  • 468
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在VC++通过汇编实现获取代码运行时间
举报原因:
原因补充:

(最多只允许输入30个字)