C++统计程序运行时间的类

5 篇文章 0 订阅

这个类统计代码真正运行的时间,如果代码运行过程中cpu被剥夺了,那么被剥夺的那段时间是不计算在内的。

class CStopwatch
{
public:
	CStopwatch()
	{
		Start();
	}

	__int64 Now() const
	{
		LARGE_INTEGER liPerNow;
		QueryPerformanceCounter(&liPerNow);
		return liPerNow.QuadPart - m_liPerStart.QuadPart;
	}

private:
	void Start()
	{
		QueryPerformanceCounter(&m_liPerStart);
	}

private:
	LARGE_INTEGER m_liPerfFreq;
	LARGE_INTEGER m_liPerStart;
};

整个小例子吧,C++对于错误通常返回错误码,即一个int值。这样子导致的问题是每调用一次函数需要通过返回值来判断调用是否成功,如果不成功,可能需要返回,但是返回直接需要清理之前申请的资源。每一步都要如此,所以很麻烦。所以有两种方案:

(1)一个是用do while(0)。先申请资源,然后在do while(0)中写逻辑,如果失败,则break,然后在do while结束之后统一资源清理

(2)抛出异常

我比较赞同用一种方案,主要是性能差别。

#include <string>
#include <sstream>
#include <iostream>
#include <queue>
#include <windows.h>
#include <thread>
#include <fstream>

#include <Psapi.h>
#pragma comment (lib,"Psapi.lib")

int Test()
{
	int iRet = 0;
	do
	{
		int a = 1;
		iRet = 1;
		break;
		int b = 2;
	} while (0);
	
	return iRet;
}

int Test2()
{
	int iRet = 0;
	try
	{
		int a = 1;
		throw 1;
		int b = 2;
	}
	catch (...)
	{
		iRet = 1;
	}
	
	return iRet;
}

int main()
{
	CStopwatch watch;
	Test();
	__int64 a = watch.Now();
	std::cout << a << std::endl;

	CStopwatch watch2;
	Test2();
	__int64 b = watch2.Now();
	std::cout << b << std::endl;

	std::cout << "Hello World!\n";

	system("pause");
	return 1;
}

大家可以运行下程序,感受下如果采用抛出异常处理,代价有多大。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
(1) 测试日期成员函数,在主函数中列出菜单选项,可以完成日期的加减比较等测试功能。 (2) 完善程序功能,在日期相加的菜单选项中增加日期加天数,结果为新日期;日期家月份,结果为新日期,要考虑闰年情况。 (3) 完善程序功能,在日期相减的菜单选项中增加日期减天数,结果为新日期;日期减月份,结果为新日期,要考虑闰年情况。 (4) 显示日期时增加显示星期及英文形式的月份的功能。 (5) 增加输入的甄别功能,即输入非法数据(如负数、日期超过31天、时间超过24小时等情况)的识别显示功能。 (1) 仿照日期编写时间CTime_t,可以完成时间的设置、运算、比较等功能。 (2) 增加时间的输入功能,既可以选择输入格式,可以输入hh:mm:ss格式的信息。 (3) 增加时间的输出格式,可以输出12小时的时间格式。 (4) 编写时间和日期的派生CDati,完成日期与时间的联合设置、运算、比较等功能,要求该派生可以完成:日期时间加天数或时间等于新的日期时间,日期时间减天数或等于新的日期时间,两个日期时间相减等于天数或时间等工作,在程序中考虑闰年等具体情况,并重载各种运算符。 (5) 增加输入的甄别功能,即输入非法数据,即输入非法数据(如负数、日期超过31天、时间超过24小时等情况)的识别显示功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值