栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

目标

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 
#include 
#include 

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::system_clock::now().time_since_epoch()).count();
            break;
        case nanoS:
            t.now_ = std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        default:
            t.now_ = std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count(); 
            break;
        }
        return t;
    }

    double toSec()
    {
        switch (tuS_)
        {
        case milliS:
            stamp_ = static_cast(now_) * 0.001;
            break;
        case nanoS:
            stamp_ = static_cast(now_) * 1.e-9;
            break;
        default:
            stamp_ = static_cast(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 
#include 
#include 

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::system_clock::now().time_since_epoch()).count();
            break;
        case nanoS:
            t.now_ = std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count();
            break;
        default:
            t.now_ = std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count(); 
            break;
        }
        return t;
    }

    double toSec()
    {
        switch (tu_)
        {
        case milliS:
            stamp_ = static_cast(now_) * 0.001;
            break;
        case nanoS:
            stamp_ = static_cast(now_) * 1.e-9;
            break;
        default:
            stamp_ = static_cast(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 elapsed_seconds = end - start;
        return elapsed_seconds.count() * 1000;
    }

private:
    std::chrono::time_point start, end;
};

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/769154.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号