依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 33|回复: 0

VC++MFC中取得一个函数的运行时间

[复制链接] 主动推送

1733

主题

1739

帖子

2658

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
2658
发表于 2024-9-18 14:28:24 | 显示全部楼层 |阅读模式
VC++MFC中取得一个函数的运行时间
在VC++ MFC中,可以使用  `CTime`  类或 Windows API 中的  `QueryPerformanceCounter`  和  `QueryPerformanceFrequency`  函数来测量函数的运行时间。下面是一个使用  `QueryPerformanceCounter`  的示例,展示如何在MFC应用程序中获取一个函数的运行时间:
### 示例代码
  1. #include <afx.h> // MFC核心和标准组件
  2. #include <windows.h>
  3. #include <iostream>
  4. void ExampleFunction() {
  5.     // 模拟一些工作
  6.     Sleep(1000); // 暂停1秒
  7. }
  8. void MeasureExecutionTime(void (*func)()) {
  9.     LARGE_INTEGER frequency; // 计数器频率
  10.     LARGE_INTEGER start;     // 开始时间
  11.     LARGE_INTEGER end;       // 结束时间
  12.      // 获取计数器的频率
  13.     QueryPerformanceFrequency(&frequency);
  14.      // 获取开始时间
  15.     QueryPerformanceCounter(&start);
  16.      // 调用目标函数
  17.     func();
  18.      // 获取结束时间
  19.     QueryPerformanceCounter(&end);
  20.      // 计算运行时间(单位:毫秒)
  21.     double elapsedTime = static_cast<double>(end.QuadPart - start.QuadPart) * 1000.0 / frequency.QuadPart;
  22.      // 输出运行时间
  23.     CString message;
  24.     message.Format(_T("Function execution time: %.3f ms"), elapsedTime);
  25.     AfxMessageBox(message); // 使用MFC的消息框显示结果
  26. }
  27. int main() {
  28.     // 初始化MFC
  29.     AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0);
  30.      MeasureExecutionTime(ExampleFunction); // 测量 ExampleFunction 的运行时间
  31.     return 0;
  32. }
复制代码


### 说明
1. ** `QueryPerformanceFrequency` ** 和 ** `QueryPerformanceCounter` **:这两个函数用于高精度地测量时间。 `QueryPerformanceFrequency`  获取计数器的频率,而  `QueryPerformanceCounter`  获取当前计数器的值。
2. ** `ExampleFunction` **:这是一个示例函数,可以替换为你需要测量的任意函数。
3. **时间计算**:通过计算结束时间与开始时间的差值,并结合计数器的频率,得到函数的运行时间(单位为毫秒)。
4. **MFC消息框**:使用  `AfxMessageBox`  来显示运行时间的结果。
### 注意事项
- 在 MFC 应用程序中,确保正确初始化 MFC 环境。
- 如果在非MFC环境中使用该代码,可能需要调整消息框显示部分。
运行该程序后,你将看到  `ExampleFunction`  的执行时间以消息框的形式显示。你可以根据需要替换  `ExampleFunction`  为其他需要测量的函数。






下面是使用  `CTime`  类来测量函数运行时间的示例代码,适用于VC++ MFC环境:
  1. #include <afx.h> // MFC核心和标准组件
  2. #include <iostream>
  3. #include <windows.h>
  4. void ExampleFunction() {
  5.     // 模拟一些工作
  6.     Sleep(1000); // 暂停1秒
  7. }
  8. void MeasureExecutionTime(void (*func)()) {
  9.     // 获取开始时间
  10.     CTime startTime = CTime::GetCurrentTime();
  11.      // 调用目标函数
  12.     func();
  13.      // 获取结束时间
  14.     CTime endTime = CTime::GetCurrentTime();
  15.      // 计算运行时间
  16.     CTimeSpan timeSpan = endTime - startTime;
  17.      // 输出运行时间
  18.     CString message;
  19.     message.Format(_T("Function execution time: %d ms"), timeSpan.GetTotalMilliseconds());
  20.     AfxMessageBox(message); // 使用MFC的消息框显示结果
  21. }
  22. int main() {
  23.     // 初始化MFC
  24.     AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0);
  25.      MeasureExecutionTime(ExampleFunction); // 测量 ExampleFunction 的运行时间
  26.     return 0;
  27. }
复制代码


### 说明:
1. ** `CTime`  类**: `CTime`  用于获取当前时间。 `CTime::GetCurrentTime()`  方法返回当前的时间。
2. ** `CTimeSpan`  类**:用于表示时间间隔。通过计算结束时间和开始时间的差值,得到函数的运行时间。
3. ** `ExampleFunction` **:这是一个示例函数,可以替换为你需要测量的任意函数。
4. **时间计算**:使用  `GetTotalMilliseconds()`  方法获取时间间隔的总毫秒数。
5. **MFC消息框**:使用  `AfxMessageBox`  显示运行时间的结果。
### 注意事项:
- 确保在 MFC 应用程序中正确初始化 MFC 环境。
- 如果在非MFC环境中使用该代码,可能需要调整消息框显示部分。
运行该程序后,你将看到  `ExampleFunction`  的执行时间以消息框的形式显示。你可以根据需要替换  `ExampleFunction`  为其他需要测量的函数。

相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员5折;永久VIP免费
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2024-9-27 11:37

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表