博客
关于我
四. 创建工作空间与功能包
阅读量:511 次
发布时间:2019-03-07

本文共 1564 字,大约阅读时间需要 5 分钟。

文章目录

一. 工作空间(workspace)

概念:

工作空间(workspace)是一个存放工程开发 相关文件的文件夹。(可以理解为一些IDE,例如VStudio第一步创建的工程)
包含的四个主要文件夹:

  1. • src:代码空间(Source Space)
    用来放置功能包;
  2. • build:编译空间(Build Space)
    放置编译过程中所产生的中间文件,基本上我们不用关心
  3. • devel:开发空间(Development Space)
    放置编译过程中生成的可执行文件,一些库,脚本等;
  4. • install:安装空间(Install Space)
    用install命令安装的东西存放的位置 和 放置结果可执行文件

注: devel和 install里的内容是有些重复的,所以ROS_2里只保留了 install,但是ROS_1里还是存在devel和 install。

二. 创建工作空间

1.创建工作空间

$ mkdir -p ~/catkin_ws/src   //catkin_ws是工作空间的名字,随便取;src不能变;$ cd ~/catkin_ws/src $ catkin_init_workspace  //把当前文件夹变成ROS工作空间的一个属性;

2.编译工作空间

$ cd ~/catkin_ws/ $ catkin_make  //这个指令会编译src下所有源码,结果放到devel和 install里;

注: catkin_make命令会产生build和devel文件夹,要产生install需再执行 catkin_make install

3.设置环境变量

$ source devel/setup.bash  //因为很多可执行文件都是在工作空间里放置的,为了让系统找得到这些可执行文件,需要这样设置环境变量;

4.检查环境变量

用echo命令显示ROS的环境变量;$ROS_PACKAGE_PATH  ---ROS的环境变量$ echo $ROS_PACKAGE_PATH  查找并显示工作空间下所有功能包的路径

三. 创建功能包

注:

所有的源码必须放在功能包里,不能直接放在src下;

命令:

$ catkin_create_pkg 
[depend1] [depend2] [depend3] ...这些依赖,是自己创建的功能包所需的功能包(库),相当于C++里的#include

例子:

1.创建功能包

$ cd ~/catkin_ws/src $ catkin_create_pkg test_pkg std_msgs rospy roscpp创建的test_pkg功能包需要依赖std_msgs rospy roscpp,因为创建的test_pkg功能包需要调用python和c++接口来写程序;std_msgs是ROS定义的一些标准的消息结构,eg:int , bool等;

2.编译功能包

$ cd ~/catkin_ws $ catkin_make

3.设置环境变量

编译成功之后,要想运行功能包里的某一个程序,需要设置工作空间的环境变量。用以下命令;只有设置了这个环境变量之后,才能让系统找到这个工作空间;$ source ~/catkin_ws/devel/setup.bash

4.检查环境变量

在这里插入图片描述

注:

同一个工作空间下,不允许存在同名功能包 不同工作空间下,允许存在同名功能包

四. 功能包下的两个文件(CMakeLists.txt和package.xml)

在这里插入图片描述

注:
首先每个功能包都有这两个文件。
package.xml
描述与功能包相关的信息,eg:功能包的名字,版本号,维护者邮箱等;
CMakeLists.txt
描述功能包的编译规则;

转载地址:http://ouunz.baihongyu.com/

你可能感兴趣的文章
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>