之前由于想统计代码中每个模块加载时长,因此写了一个模块加载时长统计类,使用起来也是超级方便,只需要定义一个宏即可

使用方式如下:

1、统计函数性能

void func()
{
CONSUMING_OUTPUT("className");
}

2、统计函数中某个模块加载时长

void func()
{
...
{
//funcation code
CONSUMING_OUTPUT("code");
}
...
}

3、统计类的存活时长

class A()
{
... CONSUMING_OUTPUT("A life time");
}

//性能查看方便类代码如下

#include <time.h>
#include <windows.h>
#include <iostream> struct PerformanceCheck
{
public:
PerformanceCheck(const std::wstring & message) :m_Message(message)
{
m_Start = clock();
}
~PerformanceCheck()
{
m_End = clock(); wchar_t str[1024]; wsprintf(str, L"%s:%d\n", m_Message.c_str(), (long)((double)(m_End - m_Start) / (double)(CLOCKS_PER_SEC)* 1000.0)); #ifdef _DEBUG
OutputDebugString(str);
#else
RLBase::WriteProgramLogNoMask(str);
#endif // DEBUG
} private:
clock_t m_Start;
clock_t m_End;
std::wstring m_Message;
}; #define PerformanceOutput //是否启用性能输出 #ifdef PerformanceOutput
#define CONSUMING_OUTPUT(a) PerformanceCheck c(a)
#else
#define CONSUMING_OUTPUT(a)
#endif
如果您觉得文章不错,不妨给个打赏,写作不易,感谢各位的支持。您的支持是我最大的动力,谢谢!!!

很重要--转载声明

  1. 本站文章无特别说明,皆为原创,版权所有,转载时请用链接的方式,给出原文出处。同时写上原作者:朝十晚八 or Twowords

  2. 如要转载,请原文转载,如在转载时修改本文,请事先告知,谢绝在转载时通过修改本文达到有利于转载者的目的。


最新文章

  1. selenium 页面截图并保存
  2. python 反射
  3. JS中数据类型及原生对象简介
  4. wp8 入门到精通 线程
  5. 创建类模式(四):原型(Prototype)
  6. 一张图看懂DNS域名解析全过程
  7. HDU3336 Count the string
  8. c#使用GDI+简单绘图
  9. AspectCore中的IoC容器和依赖注入
  10. Apache+PHP+Mysql中文配置
  11. (三) 查看USB设备
  12. Day02_Python基础学习今日总结
  13. windows 服务的安装与卸载之bat脚本命令
  14. Eclipse 在高分辨率4K显示器下图标按钮过小
  15. String类中的equals()方法:
  16. (转)Ubuntu init启动流程分析
  17. set的三种遍历方式-----不能用for循环遍历(无序)
  18. selenium自动化测试之整合测试报告
  19. sqljdbc4.jar的安装
  20. js formData图片上传(单图上传、多图上传)后台java

热门文章

  1. 你真的了JMeter解聚合报告么?
  2. Go-json解码到接口及根据键获取值
  3. ansible模块介绍之ios_facts
  4. 基于mybatisPlus的特殊字符校验
  5. shell习题1
  6. Salesforce LWC学习(五) LDS &amp; Wire Service 实现和后台数据交互 &amp; meta xml配置
  7. 撤销git add添加的文件
  8. ResourceManager学习之Application,状态机管理
  9. Java NIO 上
  10. fiddler的安装于使用(一)安装fiddler