ros::NodeHandle与命名空间的那些事儿

两个用途

  1. 首先,它提供简单的启动和关闭roscpp程序内部节点。
  2. 其次,它提供了额外的命名空间解析层,可以使编写子组件更容易。

自动启动和关闭

ros :: NodeHandle管理内部引用计数,以便启动和关闭节点,如下所示:

ros :: NodeHandle nh;

在创建时,如果内部节点尚未启动,则ros​​ :: NodeHandle将启动该节点。一旦所有ros :: NodeHandle实例都被销毁,该节点将自动关闭。

命名空间

NodeHandles允许您为其构造函数指定命名空间:

ros :: NodeHandle nh(“my_namespace”);

这使得与该NodeHandle相关的命名空间为<node_namespace> / my_namespace,而不仅仅是<node_namespace>。

您还可以指定父NodeHandle和要追加的命名空间:

ros :: NodeHandle nh1(“ns1”);
ros :: NodeHandle nh2(nh1,“ns2”);

这会将nh2放入<node_namespace> / ns1 / ns2命名空间。

全局名称

如果您真的想要,可以指定全局名称:

ros :: NodeHandle nh(“/ my_global_namespace”);

通常不鼓励这样做,因为它阻止节点被推入命名空间(例如通过roslaunch)。但是有时候在代码中使用全局名称会很有用。

私人名称

使用私有名称比直接使用私有名称(“~name”)调用NodeHandle方法有点琐碎。相反,您必须在私有命名空间内创建一个新的NodeHandle:

ros :: NodeHandle nh(“~my_private_namespace”);
ros :: Subscriber sub = nh.subscribe(“my_private_topic”,...);

上面的示例将订阅<node_name> / my_private_namespace / my_private_topic

ros::NodeHandleROS中的一个重要类,用于ROS系统进行通信和交互。它提供了一系列方法和功能,用于创建和管理ROS节点、发布和订阅ROS话题、调用和提供ROS服务等。 以下是ros::NodeHandle的一些常见用法和功能: 1. 创建NodeHandle对象: ```cpp #include <ros/ros.h> int main(int argc, char** argv) { // 初始化ROS节点 ros::init(argc, argv, "my_node"); // 创建NodeHandle对象 ros::NodeHandle nh; // 其他操作... return 0; } ``` 2. 发布和订阅ROS话题: ```cpp #include <ros/ros.h> #include <std_msgs/String.h> int main(int argc, char** argv) { ros::init(argc, argv, "my_node"); ros::NodeHandle nh; // 创建发布者 ros::Publisher pub = nh.advertise<std_msgs::String>("my_topic", 10); // 创建订阅者 ros::Subscriber sub = nh.subscribe("my_topic", 10, callback); // 其他操作... ros::spin(); return 0; } void callback(const std_msgs::String::ConstPtr& msg) { // 处理接收到的消息 } ``` 3. 调用和提供ROS服务: ```cpp #include <ros/ros.h> #include <std_srvs/Empty.h> bool my_service(std_srvs::Empty::Request& req, std_srvs::Empty::Response& res) { // 处理服务请求 return true; } int main(int argc, char** argv) { ros::init(argc, argv, "my_node"); ros::NodeHandle nh; // 创建服务服务器 ros::ServiceServer server = nh.advertiseService("my_service", my_service); // 创建服务客户端 ros::ServiceClient client = nh.serviceClient<std_srvs::Empty>("my_service"); // 其他操作... return 0;} ``` 4. 获取ROS参数: ```cpp #include <ros/ros.h> int main(int argc, char** argv) { ros::init(argc, argv, "my_node"); ros::NodeHandle nh; // 获取参数 int my_param; nh.getParam("my_param", my_param); // 设置参数 nh.setParam("my_param", 123); // 其他操作... return 0; } ``` 这些只是ros::NodeHandle的一部分功能,它还提供了许多其他方法和功能,用于ROS系统进行更高级的交互和通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

abcwoabcwo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值