首页 > 代码库 > Mr_matcher的细节2
Mr_matcher的细节2
1.参数服务器
ROS参数服务器能保存数据类型包括:strings, integers, floats, booleans, lists, dictionaries, iso8601 dates, and base64-encoded data。Dictionaries则必需有字符串key值。
roscpp参数API能支持全部类型,多数情况容易使用的类型有:strings, integers, floats and booleans,使用其他类型参考XmlRpc::XmlRpcValue class
roscpp有两个版本的API接口:bare版和handle版。
bare版:在 ros::param 命令空间下。
handle版:通过ros::NodeHandle接口使用。
2.获取参数
从参数服务器获取值,每个版本都支持strings, integers, doubles, booleans 和XmlRpc::XmlRpcValue
返回 false代表参数不存在或不是正确的类型。
1)NodeHandle版本
ros::NodeHandle::getParam()
NodeHandle版本:参数相对于NodeHandle的命名空间进行解析。
ros::NodeHandle nh; std::string global_name, relative_name, default_param; if (nh.getParam("/global_name", global_name)) { ... } if (nh.getParam("relative_name", relative_name)) { ... } // Default value version nh.param<std::string>("default_param", default_param, "default_value");
3.设置参数
NodeHandle版本
ros::NodeHandle::setParam() NodeHandle版本:参数相对于NodeHandle的命名空间进行解析 ros::NodeHandle nh; nh.setParam("/global_param", 5); nh.setParam("relative_param", "my_string"); nh.setParam("bool_param", false);
4.检查参数是否存在
handle版:ros::NodeHandle::hasParam() ros::NodeHandle nh; if (nh.hasParam("my_param")) { ... }
5.删除参数
handle版:ros::NodeHandle::deleteParam()
ros::NodeHandle nh;
nh.deleteParam("my_param");
6.访问私有参数
handle版:创建的ros::NodeHandle实例,并提供私有的命名空间作为其命名空间 ros::NodeHandle nh("~"); std::string param; nh.getParam("private_name", param);
参考http://www.ncnynl.com/archives/201702/1295.html
Mr_matcher的细节2
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。