仿ROS的C++版本时间管理类

29 篇文章 3 订阅
8 篇文章 0 订阅

目标

1. 设计C++时间管理类,实现类似ROS中ros::Time::now()功能,能够直接输出double类型的时间戳。不过有所变化:可以选择时间戳的精度;

2. 可以获取时间段,比如用于计算频率/帧率,统计代码耗时等。

实施

目标1

在函数体static TimeUtil now()中使用非静态变量时,会报错:

Error: invalid use of member in static member function

c++ - Error: invalid use of member in static member function - Stack Overflowhttps://stackoverflow.com/questions/17391853/error-invalid-use-of-member-in-static-member-functioninvalid use of member in static member function - arduino - Stack Overflowhttps://stackoverflow.com/questions/55105861/invalid-use-of-member-in-static-member-function-arduino

整体代码如下:

#ifndef TIME_UTIL_H_
#define TIME_UTIL_H_

#include <ctime>
#include <cstdlib>
#include <chrono>

enum TimeUnit{milliS, microS, nanoS}; //毫秒,微秒,纳秒, 默认微秒

class TimeUtil
{
 public:
    TimeUtil()
    {
    }

    TimeUtil(TimeUnit timeUnit)
    // :tu_(timeUnit)
    {
        tuS_ = timeUnit;
    }

    TimeUtil(const double &stamp)
        :now_(stamp * 1000)
    {
    }

    ~TimeUtil(){}

    static TimeUtil now()
    {
        TimeUtil t;
        switch (tuS_)
        {
        case milliS:
            t.now_ = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        case nanoS:
            t.now_ = std::chrono::duration_cast<std::chrono::nanoseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        default:
            t.now_ = std::chrono::duration_cast<std::chrono::microseconds>(std::chrono::system_clock::now().time_since_epoch()).count(); 
            break;
        }
        return t;
    }

    double toSec()
    {
        switch (tuS_)
        {
        case milliS:
            stamp_ = static_cast<double>(now_) * 0.001;
            break;
        case nanoS:
            stamp_ = static_cast<double>(now_) * 1.e-9;
            break;
        default:
            stamp_ = static_cast<double>(now_) * 1.e-6;
            break;
        }
        return stamp_;
    }

private:
    uint64_t now_;
    double stamp_;
    // TimeUnit tu_;
    static TimeUnit tuS_;
};

#endif

 因为ROS的多了一个精度选择,所以需要变量,完全仿ROS的话,使用时要给static TimeUnit tuS_;在目标对象定义一次,不大好用。

c++ - Undefined reference to static variable - Stack Overflowhttps://stackoverflow.com/questions/14331469/undefined-reference-to-static-variable

因此就不完全仿ROS的格式,改成以下代码算了:

#ifndef TIME_UTIL_H_
#define TIME_UTIL_H_

#include <ctime>
#include <cstdlib>
#include <chrono>

enum TimeUnit{milliS, microS, nanoS}; //毫秒,微秒,纳秒, 默认微秒

class TimeUtil
{
 public:
    TimeUtil()
    {
    }

    TimeUtil(TimeUnit timeUnit)
    :tu_(timeUnit)
    {
    }

    TimeUtil(const double &stamp)
        :now_(stamp * 1000)
    {
    }

    ~TimeUtil(){}

    TimeUtil now()
    {
        TimeUtil t;
        switch (tu_)
        {
        case milliS:
            t.now_ = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        case nanoS:
            t.now_ = std::chrono::duration_cast<std::chrono::nanoseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        default:
            t.now_ = std::chrono::duration_cast<std::chrono::microseconds>(std::chrono::system_clock::now().time_since_epoch()).count(); 
            break;
        }
        return t;
    }

    double toSec()
    {
        switch (tu_)
        {
        case milliS:
            stamp_ = static_cast<double>(now_) * 0.001;
            break;
        case nanoS:
            stamp_ = static_cast<double>(now_) * 1.e-9;
            break;
        default:
            stamp_ = static_cast<double>(now_) * 1.e-6;
            break;
        }
        return stamp_;
    }

private:
    uint64_t now_;
    double stamp_;
    TimeUnit tu_;
};

使用时定义一下,就可以获得double类型的时间戳了。

    TimeUtil stamp;
    cout << "fusion and vo calibration first time: " << stamp.now().toSec() << endl;

目标2

整体代码如下:

class TicToc
{
public:
    TicToc()
    {
        tic();
    }

    void tic()
    {
        start = std::chrono::system_clock::now();
    }

    double toc()
    {
        end = std::chrono::system_clock::now();
        std::chrono::duration<double> elapsed_seconds = end - start;
        return elapsed_seconds.count() * 1000;
    }

private:
    std::chrono::time_point<std::chrono::system_clock> start, end;
};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值