以文本方式输出函数执行时间相关信息

相应的封装类代码:

.h文件

#pragma once
#include<iostream>
#include <time.h>
#include<fstream>
using namespace std;

class testTxtOutput
{
private:
	//开始计时
	clock_t timeStart;
	//结束计时
	clock_t timeEnd;
	//该段程序这一次执行时间
	clock_t runTime;
	//该段程序这一次执行的总时间
	 clock_t sumTime;
	//平均执行时间
	 clock_t avgTime;
	//最大执行时间
	 clock_t maxTime;
	//统计执行帧的帧数
	 long countFrame;

public:
	//开始计时
	void openClocker(void);
	//结束计时
	void closeClocker();
	//作为用户接口完成整个文件的读写
	void writeToTxt(string funcName);
	//计算相应的时间
	void calculateTime();
public:
	testTxtOutput(void);
	~testTxtOutput(void);
	
};

 

.cpp文件

#include "StdAfx.h"
#include "testTxtOutput.h"


testTxtOutput::testTxtOutput(void):
	timeStart(0),
	timeEnd(0),
	runTime(0),
	sumTime(0),
	avgTime(0),
	maxTime(0),
	countFrame(0)
{
}


testTxtOutput::~testTxtOutput(void)
{
}


void testTxtOutput::openClocker(void)
{
	timeStart = 0;
	runTime = 0;
	timeEnd = 0;
	timeStart = clock();
}


void testTxtOutput::closeClocker(void)
{
	timeEnd = clock();
}


void testTxtOutput::writeToTxt(string funcName)
{

	string cloneFunc =funcName;
	funcName += ".txt";
	calculateTime();
	ofstream fout;
	fout.open(funcName,ofstream::out | ofstream::app);
	fout<<cloneFunc.c_str()<<":第"<<countFrame<<"帧执行"
		<<"		"<<"执行时间(ms):"<<runTime
		<<"		"<<"最大执行时间(ms):"<<maxTime
		<<"		"<<"平均执行时间(ms):"<<avgTime<<endl;
}

void testTxtOutput::calculateTime()
{
	countFrame++;
	runTime = timeEnd - timeStart;
	sumTime +=  runTime;
	avgTime = sumTime/countFrame;
	maxTime = maxTime>runTime ? maxTime : runTime;
}


 

main函数的调用:

 

// txtoutput.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include"testTxtOutput.h"

int _tmain(int argc, _TCHAR* argv[])
{
	testTxtOutput out;
	out.writeToTxt("yangjie");

	system("pause");
	return 0;
}

用法说明:

在需要的多次测试时间的函数执行文件中,包含该.h文件,并创建一个全局的实例。在测试函数的前面调用openClocker(),在函数的后面调用closeClocker()和writeToTxt()函数。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值