linux精确分析函数运行时间

30 篇文章 2 订阅

网上大部分用clock函数,在线程中计算某个函数运行时间,很不精确

#ifndef PROFILER_H
#define PROFILER_H


#include <time.h>
#include <sys/time.h>
#include <stdio.h>
#include <stdlib.h>

class profiler
{

public:
    profiler(const char* func_name)
    {
        gettimeofday(&tv, NULL);
        m_func_name = func_name;
    }


    ~profiler()
    {
        struct timeval tv2;
        gettimeofday(&tv2, NULL);
        long cost = (tv2.tv_sec - tv.tv_sec) * 1000000 + (tv2.tv_usec - tv.tv_usec);
        printf("[%s]cost=%d ms\n", m_func_name, cost / 1000);
    }

private:
    struct timeval tv;
    const char * m_func_name;
};



#define PROFILER() profiler ____profiler_instance##__LINE__(__FUNCTION__)




#endif // PROFILER_H

 

 

 

不精确的做法:

static clock_t m_cockStart;
void closkStart()
{
    m_cockStart = clock();
}

void clockFinish(const char* msg)
{
    clock_t finish;
    double total_time;
    finish = clock();
    total_time = (double)(finish-m_cockStart) / CLOCKS_PER_SEC;
    printf( "%s:%f seconds\n", msg, total_time);
}

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值