• ROS中关于时间的API


    目录

    1.时刻

    2.持续时间

    3.持续时间与时刻运算

    4.设置运行频率

    5.定时器


    下面是关于利用时间API的C++代码,执行之前请记得创建功能包,在src文件夹下创建C++文件

    1.时刻

    获取时刻&设置指定时刻

    1. //获取时刻
    2. ros::init(argc,argv,"hello_time");
    3. ros::NodeHandle nh;//必须创建句柄,否则时间没有初始化,导致后续API调用失败
    4. ros::Time right_now = ros::Time::now();//将当前时刻封装成对象
    5. ROS_INFO("当前时刻:%.2f",right_now.toSec());//获取距离 1970年01月01日 00:00:00 的秒数
    6. ROS_INFO("当前时刻:%d",right_now.sec);//获取距离 1970年01月01日 00:00:00 的秒数
    7. //设置指定时间
    8. ros::Time someTime(100,100000000);// 参数1:秒数 参数2:纳秒
    9. ROS_INFO("时刻:%.2f",someTime.toSec()); //100.10
    10. ros::Time someTime2(100.3);//直接传入 double 类型的秒数
    11. ROS_INFO("时刻:%.2f",someTime2.toSec()); //100.30

    运行效果:

    2.持续时间

    设置一个时间区间(间隔):

    1. ROS_INFO("当前时刻:%.2f",ros::Time::now().toSec());
    2. ros::Duration du(10);//持续10秒钟,参数是double类型的,以秒为单位
    3. du.sleep();//按照指定的持续时间休眠
    4. ROS_INFO("持续时间:%.2f",du.toSec());//将持续时间换算成秒
    5. ROS_INFO("当前时刻:%.2f",ros::Time::now().toSec());

    效果展示:

    3.持续时间与时刻运算

    为了方便使用,ROS中提供了时间与时刻的运算:

    1. ROS_INFO("时间运算");
    2. ros::Time now = ros::Time::now();
    3. ros::Duration du1(10);
    4. ros::Duration du2(20);
    5. ROS_INFO("当前时刻:%.2f",now.toSec());
    6. //1.time 与 duration 运算
    7. ros::Time after_now = now + du1;
    8. ros::Time before_now = now - du1;
    9. ROS_INFO("当前时刻之后:%.2f",after_now.toSec());
    10. ROS_INFO("当前时刻之前:%.2f",before_now.toSec());
    11. //2.duration 之间相互运算
    12. ros::Duration du3 = du1 + du2;
    13. ros::Duration du4 = du1 - du2;
    14. ROS_INFO("du3 = %.2f",du3.toSec());
    15. ROS_INFO("du4 = %.2f",du4.toSec());
    16. //PS: time 与 time 不可以运算
    17. // ros::Time nn = now + before_now;//异常

    效果展示:

    ps:时刻与时刻之间可以相减,但不能相加

    4.设置运行频率

    1. ros::Rate rate(1);//指定频率
    2. while (true)
    3. {
    4. ROS_INFO("-----------code----------");
    5. rate.sleep();//休眠,休眠时间 = 1 / 频率。
    6. }

    效果展示:

    5.定时器

    ROS 中内置了专门的定时器,可以实现与 ros::Rate 类似的效果:

    ROS定时器实现逻辑:

    1)创建一个定时器,按照指定频率调用回调函数

    2)参数设置

    1. /Timer createTimer(Duration period, const TimerCallback& callback, bool oneshot = false,
    2. // bool autostart = true) const;
    1. * \param period 时间间隔
    2. * \param callback 回调函数
    3. * \param oneshot 如果设置为 true,只执行一次回调函数,设置为 false,就循环执行。
    4. * \param autostart 如果为true,返回已经启动的定时器,设置为 false,需要手动启动。

     代码如下:

    1. ros::NodeHandle nh;//必须创建句柄,否则时间没有初始化,导致后续API调用失败
    2. ros::Timer timer = nh.createTimer(ros::Duration(0.5),doSomeThing,true);//只执行一次
    3. ros::spin(); //必须 spin

    定时器的回调函数:

    1. void doSomeThing(const ros::TimerEvent &event){
    2. ROS_INFO("-------------");
    3. ROS_INFO("event:%s",std::to_string(event.current_real.toSec()).c_str());
    4. }

    效果展示(只执行一次):

    效果展示(循环执行):

     注意:

    1.文件运行时候配置环境

    2.别忘记启动roscore(这是rosmaster)

  • 相关阅读:
    20. Spring源码篇之@Lookup详解
    类的初始化与加载
    Ph.D,指哲学博士学位
    服务器部署项目总结
    Kafka3.x核心速查手册二、客户端使用篇-6、消息发送幂等性
    【面试普通人VS高手系列】lock和synchronized区别
    代码随想录算法训练营第二十一天 | LeetCode 235. 二叉搜索树的最近公共祖先、701. 二叉搜索树中的插入操作、450. 删除二叉搜索树中的节点
    低代码热潮下的冷思考:为何我们不能盲目追随
    Algorithm基础算法学习
    接口测试练习步骤
  • 原文地址:https://blog.csdn.net/weixin_52493604/article/details/136408886