ROS1中source xxx.bash失效

如题,你在bashrc中写了source xxx.bash,但是你打开新的终端后,提示报错,并且找不到这个package

即使你在bashrc中写了

不知道原因之前,总是觉得怪怪的,知道原因后,其实很简单。

这里其实就是ROS工作空间source的核心机制 ------每个工作空间的setup.bash不是简单"追加"路径,而是基于该工作空间编译时的依赖关系,重新构建ROS_PACKAGE_PATH

一、核心机制

每个ROS工作空间编译(catkin_make/catkin build)时,会在devel/setup.bash中记录:

  1. 该工作空间编译时,生效的「父工作空间」(也就是当时ROS_PACKAGE_PATH里的路径);
  2. 当你source这个setup.bash时,ROS会:
    • 当前工作空间的路径放到最前面(最高优先级);
    • 然后拼接上编译时记录的「父工作空间」路径;
    • 最后只保留系统ROS路径(/opt/ros/noetic/share);
    • 不会保留之前手动source过的、但和当前工作空间无关的路径

简单说:source一个工作空间的setup.bash,相当于"重置"ROS_PACKAGE_PATH,只保留「当前工作空间 + 它编译时依赖的工作空间 + 系统ROS」。

二、我这边做了测试

1. 初始状态(.bashrc加载后的默认值)
bash 复制代码
echo $ROS_PACKAGE_PATH 
/home/wu/code/ros/neor_mini/mini_sim18_ws/src:/home/wu/grasp_ws/src:/home/wu/catkin_workspace/src:/home/wu/catkin_ws/src:/opt/ros/noetic/share
  • 原因:.bashrc里最后source的是mini_sim18_ws,且mini_sim18_ws编译时依赖了grasp_wscatkin_workspacecatkin_ws,所以初始路径包含这些。
2. source catkin_ws
bash 复制代码
echo $ROS_PACKAGE_PATH 
/home/wu/catkin_ws/src:/home/wu/Moveit_test03_ws/src:/opt/ros/noetic/share
  • 原因:catkin_ws编译时只依赖Moveit_test03_ws和系统ROS,所以source它时,ROS会"重置"路径,只保留catkin_ws(当前) + Moveit_test03_ws(父) + 系统ROS,删掉了mini_sim18_wsgrasp_ws等无关路径
3. source catkin_workspace
bash 复制代码
echo $ROS_PACKAGE_PATH 
/home/wu/catkin_workspace/src:/home/wu/catkin_ws/src:/opt/ros/noetic/share
  • 原因:catkin_workspace编译时依赖catkin_ws和系统ROS,所以source后路径变成:catkin_workspace(当前) + catkin_ws(父) + 系统ROS,删掉了Moveit_test03_ws
4. source Moveit_test03_ws
bash 复制代码
echo $ROS_PACKAGE_PATH 
/home/wu/Moveit_test03_ws/src:/opt/ros/noetic/share
  • 原因:Moveit_test03_ws编译时没有依赖任何自定义工作空间 ,只依赖系统ROS,所以source后路径只有它自己 + 系统ROS,其他自定义工作空间路径全被删掉。
5. source mini_sim18_ws
bash 复制代码
echo $ROS_PACKAGE_PATH 
/home/wu/code/ros/neor_mini/mini_sim18_ws/src:/home/wu/grasp_ws/src:/home/wu/catkin_workspace/src:/home/wu/catkin_ws/src:/opt/ros/noetic/share
  • 原因:回到初始状态,因为mini_sim18_ws编译时依赖了grasp_wscatkin_workspacecatkin_ws,所以source后这些路径又被加回来。

每个ROS工作空间的setup.bash就像一个"预设清单":

  • 编译时:你告诉它"我依赖A、B、C工作空间",它就把A、B、C记到清单里;
  • source时:它会清空当前所有路径,只按清单加载"自己 + 依赖的A/B/C + 系统ROS"。
  • 不同工作空间的"清单"不同,所以sourceROS_PACKAGE_PATH就不一样。

总结

  1. 核心原因source工作空间的setup.bash会"重置"ROS_PACKAGE_PATH,只保留「当前工作空间 + 它编译时依赖的工作空间 + 系统ROS」,而非简单追加;
  2. 关键现象 :不同工作空间编译时的依赖不同,导致source后路径组成不同;

最后

这就是我最开始存在的困惑:为啥我bashrc中source路径放置的顺序不同,最后有些能直接跑起来,有些就是需要重新source指定bash。

相关推荐
骇客野人2 小时前
python爬虫例子,且处理反爬的网站也能爬
开发语言·爬虫·python
IMPYLH2 小时前
Bash 的 basenc 命令
linux·运维·服务器·bash·shell
程序员在线炒粉8元1份顺丰包邮送可乐2 小时前
【Java 实现】用友 BIP V5 版本与飞书集成单点登录(飞书免密登录到用友 ERP)
java·开发语言·飞书·用友 bip
铁手飞鹰2 小时前
eBUS SDK Python环境安装
开发语言·python
放下华子我只抽RuiKe52 小时前
智聊机器人进阶:从 API 调试到全功能交互界面的完美落地
开发语言·人工智能·python·机器学习·分类·机器人·交互
放下华子我只抽RuiKe52 小时前
构建企业级私有化 AI:从大模型原理到本地智聊机器人全栈部署指南
开发语言·人工智能·python·深度学习·机器学习·分类·机器人
Knight_AL2 小时前
Java 中 Date 与 LocalDate 的区别
java·开发语言·数据库
问水っ2 小时前
Qt Creator快速入门 第三版 第四章 布局管理
开发语言·qt·学习
格林威2 小时前
工业相机图像高速存储(C++版):直接IO存储方法,附Basler相机实战代码!
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机