PerformanceProfiler.h

网站建设哪家好,找
成都创新互联公司!专注于网页设计、网站建设、微信开发、
重庆小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了
潼关免费建站欢迎大家使用!
#pragma once
#include
#include
#include
PerformanceProfiler.cpp
#include "PerformanceProfiler.h"
void PPSection::Begin(int id)
{
if (id != -1) //多线程
{
lock_guard lock(_mtx);
//统计线程总的花费时间和调用次数
if (_refCountMap[id]++ == 0)
_beginTimeMap[id] = clock();
}
else //单线程
{
if (_totalRefCount++ == 0)
_totalBeginTime = clock();
}
}
void PPSection::End(int id)
{
if (id != -1) //多线程
{
lock_guard lock(_mtx);
if (--_refCountMap[id] == 0)
_costTimeMap[id] += clock() - _beginTimeMap[id];
++_callCountMap[id];
}
else //单线程
{
if (--_totalRefCount == 0)
_totalCostTime += clock() - _totalBeginTime;
++_totalCallCount;
}
}
PPSection* PerformanceProfiler::CreateSection(const char* filename, const char* function,
size_t line, const char* desc)
{
PPNode node(filename, function, line, desc);
PPSection* section = NULL;
//RAII
lock_guard lock(_mtx);
PP_MAP::iterator it = _ppMap.find(node);
if (it != _ppMap.end())
{
section = it->second;
}
else
{
section = new PPSection;
_ppMap.insert(pair(node, section));
}
return section;
}
void PerformanceProfiler::OutPut()
{
int options = ConfigManager::GetInstance()->GetOptions();
if (options & SAVE_TO_CONSOLE)
{
ConsoleSaveAdapter csa;
_OutPut(csa);
}
if (options & SAVE_TO_FILE)
{
FileSaveAdapter fsa("PerformanceProfilerReport.txt");
_OutPut(fsa);
}
}
void PerformanceProfiler::_OutPut(SaveAdapter& sa)
{
vector vInfos;
PP_MAP::iterator ppIt = _ppMap.begin();
while (ppIt != _ppMap.end())
{
PPSection* section = ppIt->second;
map::iterator timeIt;
timeIt = section->_costTimeMap.begin();
while (timeIt != section->_costTimeMap.end())
{
section->_totalCostTime += timeIt->second;
section->_totalCallCount += section->_callCountMap[timeIt->first];
++timeIt;
}
vInfos.push_back(ppIt);
++ppIt;
}
struct SortByCostTime
{
bool operator()(PP_MAP::iterator l, PP_MAP::iterator r) const
{
return (l->second->_totalCostTime) > (r->second->_totalCostTime);
}
};
//按花费时间排序
sort(vInfos.begin(), vInfos.end(), SortByCostTime());
int num = 1;
for (size_t i = 0; i < vInfos.size(); ++i)
{
ppIt = vInfos[i];
const PPNode& node = ppIt->first;
PPSection* section = ppIt->second;
//node信息
sa.Save("No.%d, Desc:%s\n", num++, node._desc.c_str());
sa.Save("Filename:%s, Line:%d, Function:%s\n",
node._filename.c_str(),
node._line,
node._function.c_str());
//section信息
map::iterator timeIt;
timeIt = section->_costTimeMap.begin();
while (timeIt != section->_costTimeMap.end())
{
int id = timeIt->first;
sa.Save("Thread:%d, CostTime:%.2f s, CallCount:%lld\n",
id,
(double)timeIt->second / 1000,
section->_callCountMap[id]);
section->_totalCostTime += timeIt->second;
section->_totalCallCount += section->_callCountMap[id];
++timeIt;
}
sa.Save("TotalCostTime:%.2f s, TotalCallCount:%lld, AverCostTime:%lld ms\n\n",
(double)section->_totalCostTime / 1000,
section->_totalCallCount,
section->_totalCostTime / section->_totalCallCount);
++ppIt;
}
}另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享题目:性能剖析器项目-创新互联
当前地址:
http://cdysf.com/article/depioe.html