C++ 性能测试 打印时间类

示例代码

#pragma once
#include <chrono>
#include <iostream>

class TimeGuard
{
public:
    TimeGuard() 
    {
        d_start_ = std::chrono::high_resolution_clock::now();
    }

    ~TimeGuard()                                                                                                                                                                                             
    {
        stop();
    }

private:
    void stop()
    {
        auto d_end = std::chrono::high_resolution_clock::now();
        auto start = std::chrono::time_point_cast<std::chrono::microseconds>(d_start_)
            .time_since_epoch().count();
        auto end = std::chrono::time_point_cast<std::chrono::microseconds>(d_end)
            .time_since_epoch().count();
        auto duration = end - start;

        double ms = duration * 0.001;
        std::cout << "total:" << ms << "ms\n";
    }

private:
    std::chrono::time_point<std::chrono::high_resolution_clock> d_start_;
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。