ROS文件系统介绍

1.ROS文件系统中的基本概念

Packages: Package是ROS系统中最底层最基本的组织,里面存放各种文件:库、工具、可执行文件等.
Manifest: 一个package描述xml文件,定义package之间的依赖关系.
Stacks: package的集合,比package这个概念高一级别
Stack Manifest: 作用类似package manifest文件,但是它是针对stack的.

在文件系统中很容易识别package和stack:
package是一个包含 manifest.xml 文件的目录.
stack是一个包含 stack.xml 文件的目录.

2.文件系统工具

ROS中大量代码分散在众多的packages和stacks之中. 命令工具ls 和 cd已不能满足检索要求。因此ROS提供了一套自己的命令工具来完成与这些命令相似的工作.

(1) 使用rospack和rosstack

两个命令用于获取相应package或者stack的目录路径.

$ rospack find [package_name]    $ rosstack find [stack_name]

$ rospack find roscpp    结果:/opt/ros/indigo/share/roscpp

(2) 使用roscd

【1】改变当前目录,允许你直接切换(cd)工作目录到某个package或者stack的目录.

$ roscd [locationname[/subdir]]     Eg:$ roscd roscpp

为了验证我们已经切换到了roscpp package 目录. 我们使用unix的命令查看路径pwd:

$ pwd
结果:/opt/ros/indigo/share/roscpp

可以看到YOUR_INSTALL_PATH/share/roscpp和之前使用rospack find得到的路径是一样的。

命令 roscd及其它的ROS命令仅适用于环境变量$ROS_PACKAGE_PATH中存在的目录路径. 使用下面的命令查看环境变量$ROS_PACKAGE_PATH:

$ echo $ROS_PACKAGE_PATH

结果:/home/wj/catkin_ws/src:/opt/ros/indigo/share:/opt/ros/indigo/stacks

$ROS_PACKAGE_PATH可以添加任意目录路径,目录路径之间 ‘:‘ 分开。

【2】roscd 也能够直接进入一个 package 或 stack的子目录中.

$ roscd roscpp/cmake
$ pwd
结果:/opt/ros/indigo/share/roscpp/cmake

(3)roscd log

命令切换到ROS储存日志文件的目录。注意如果从未运行过任何ROS程序,命令会返回目录不存在的错误。

(4)使用 rosls

作用是列出指定的package或stack中的文件及目录.

$ rosls [locationname[/subdir]]

$ rosls roscpp_tutorials
结果:cmake  launch  package.xml  srv

(5)Tab 自动完成输入

当要输入一个完整的软件包名称时会变得比较繁琐。在之前的例子中roscpp tutorials是个相当长的名称,幸运的是,一些ROS工具支持TAB 自动完成输入的功能。

Eg:roscd roscpp_tut<<< 现在请按TAB键 >>>

命令行中应该会自动补充剩余部分: $ roscd roscpp_tutorials/

总结:

ROS命令工具的的命名方式:

rospack = ros + pack(age)

roscd = ros + cd

rosls = ros + ls

时间: 2024-11-08 03:48:40

ROS文件系统介绍的相关文章

ROS文件系统介绍--2

ros初级核心教程--ROS文件系统介绍(原创博文,转载请标明出处--周学伟) 1.ROS文件系统介绍: 1.1.预备工作:本教程中我们将会用到ros-tutorials程序包,请先安装: 将 <distro> 替换成你所安装的版本(比如Jade.Indigo.hydro.groovy.fuerte等) [email protected]: sudo apt-get install ros-<distro>-ros-tutorials 1.2.快速了解文件系统概念 Packages

NFS 网络文件系统介绍

NFS网络文件系统介绍 什么是NFS系统? NFS是Network File System 的缩写,它的主要功能是通过网络让不同的机器系统之间可以彼此共享文件和目录.NFS服务器可以允许NFS客户端,将远端NFS服务器端的共享目录,挂载到本地NFS客户端中.(注NFS客户端一般为应用服务器如:web) NFS服务器端共享的目录就好像NFS客户端自己的磁盘分区和目录一样. 一般客户端挂载到本地目录的名字可以随便,但为方便管理,建议和服务器端一样比较好. NFS一般是用来存储共享视频.图片等静态数据

Linux文件系统介绍(转)

文章转自:http://www.iteye.com/topic/816268 文件系统是linux的一个十分基础的知识,同时也是学习linux的必备知识. 本文将站在一个较高的视图来了解linux的文件系统,主要包括了linux磁盘分区和目录.挂载基本原理.文件存储结构.软链接硬链接.和常见目录的介绍.相信有了这些知识对于深入的学习linux会有一定的帮助.文章例子主要是基于ubuntu发行版. 如有不对之处请大家多多指出. 1.Linux磁盘分区和目录 Linux发行版本之间的差别很少,差别主

《Linux学习并不难》文件系统管理(1):xfs文件系统介绍

18.1  <Linux学习并不难>文件系统管理(1):xfs文件系统介绍 xfs是一种高性能的64位日志文件系统,由Silicon Graphics在1993年为IRIX操作系统开发.2000年5月,以GNU通用公共许可证发布这套文件系统的源代码,之后被移植到Linux 内核上.xfs特别擅长处理大文件,同时提供平滑的数据传输. xfs文件系统主要有以下几点特性. 1.数据完全性 采用xfs文件系统,当主机发生宕机以后,由于文件系统开启了日志功能,所以磁盘上的文件不会遭到破坏.不论目前文件系

06NTFS文件系统介绍

NTFS广泛应用于win 2000开始 只有分区之后才能满足文件存储的规范,哪怕只分一个区也是分区,比如家里买了160平房子我必须按功能把房子分成一间间的 一个是管理磁盘的,一个是管理磁盘里面文件的 区分好必须格式化,这是文件系统里面所规定的,格式化就是分成一块块的 这个小格子在磁盘里面的概念叫簇 所以簇大了不太好,因为fat32会增加如下图 簇大小是否可以选择? 看win server 2008后台有几块硬盘方式以上 到08DC上一样操作 格式化好后计算机后面会多默认一个分区,随便在D盘写一个

分布式文件系统介绍

 基础介绍 分布式文件系统(Distributed File System)是指文件系统管理的物理存储资源不一定直接连接在本地节点上,而是通过计算机网络与节点相连,也就是集群文件系统,可以支持大数量的节点以及PB级的数据存储.  常见的分布式文件系统 GFS.HDFS.GridFS.mogileFS.TFS.fastDFS等. GFS(Google File System):google公司为了满足本公司需求而开发的基于linux的专有分布式文件系统.不过很可惜该系统并未开源 HDFS: Had

逻辑卷lvm 和btrs文件系统介绍

LVM揭秘  lvm的中文叫逻辑卷,英文名字叫Logical Volume Manager,它有什么作用? 通过逻辑卷LVM可以有效的管理和分配磁盘空间,可以把分散的小分区组合成一个大的卷组,从卷组中分出需要的空间做出逻辑卷,这样使得磁盘扩容和缩减方便易用.还有着备份的功能,指的就是lvm快照. 逻辑卷是怎么来的? dm: device mapper,将一个或多个底层块设备组织成一个逻辑设备的模块:注:dm是内核的功能模块 /dev/dm-#   注:从0开始编号 这个逻辑设备的文件是什么? 

CentOS启动流程、Grub legacy配置、linux kernel模块管理、伪文件系统介绍

写在前面: 博客书写牢记5W1H法则:What,Why,When,Where,Who,How. 本篇主要内容: ● 启动相关基础概念汇总 ● 启动流程 ● init程序类型     /etc/rc.d/rc     chkconfig     /etc/rc.d/rc.sysinit ● GRUB legacy     命令行接口     配置文件 ● Linux Kernel     内核模块查看与管理         lsmod         modinfo         modprob

btrfs文件系统介绍

btrfs 的特性 首先是扩展性 (scalability) 相关的特性.btrfs 最重要的设计目标是应对大型机器对文件系统的扩展性要求. Extent,B-Tree 和动态 inode 创建等特性保证了 btrfs 在大型机器上仍有卓越的表现,其整体性能而不会随着系统容量的增加而降低. 其次是数据一致性 (data integrity) 相关的特性.系统面临不可预料的硬件故障,Btrfs 采用 COW 事务技术来保证文件系统的一致性. btrfs 还支持 checksum,避免了 silen