Catkin 常用命令

一、Catkin 概述

Catkin 是 ROS(Robot Operating System)的官方构建系统,用于组织、编译和管理 ROS 包。它基于 CMake 并提供了更便捷的工作流,支持多包并行编译、依赖解析和环境配置。本文将详细介绍 Catkin 的常用命令及其应用场景。

二、工作空间初始化命令

1. 创建工作空间

代码解读

mkdir -p ~/catkin_ws/src

cd ~/catkin_ws/src catkin_init_workspace # 初始化 src 目录为 Catkin 工作空间

cd ~/catkin_ws catkin_make # 编译工作空间(生成 devel 和 build 目录)

  • 说明catkin_init_workspace 会在 src 目录下生成 CMakeLists.txt 链接文件,标记该目录为 Catkin 工作空间。
2. 创建 Catkin 包

cd ~/catkin_ws/src

catkin_create_pkg my_package roscpp rospy std_msgs # 创建名为 my_package 的包,依赖 roscpp、rospy、std_msgs

  • 参数catkin_create_pkg <包名> [依赖1] [依赖2] ...
  • 作用 :自动生成包的基本结构(package.xmlCMakeLists.txt)。

三、编译与构建命令

1. 编译工作空间

cd ~/catkin_ws catkin_make # 编译整个工作空间

  • 常用选项
    catkin_make -j4 # 使用 4 个线程并行编译(加快速度) catkin_make -DCMAKE_BUILD_TYPE=Release # 设置编译类型为 Release(优化性能) catkin_make --only-pkg-with-deps my_package # 仅编译 my_package 及其依赖
2. 增量编译

catkin_make --pkg my_package # 仅编译指定包

catkin_make --force-cmake # 强制重新运行 CMake 配置(修改 CMakeLists.txt 后需要)

3. 安装编译结果

catkin_make install # 将编译结果安装到 install 目录

  • 注意 :安装后需通过 source install/setup.bash 更新环境变量。

四、包管理命令

1. 列出工作空间中的包

catkin list # 列出所有包及其状态(已编译/未编译)

catkin list --unbuilt # 仅显示未编译的包

catkin list --quiet # 仅显示包名(无状态信息)

2. 查看包依赖关系

catkin list --deps # 显示包及其依赖关系 catkin graph # 生成依赖关系图(文本形式) catkin graph --dot > deps.dot # 生成 DOT 格式依赖图,可转换为 PDF 可视化

3. 过滤编译包

# 白名单:仅编译指定包

catkin_make -DCATKIN_WHITELIST_PACKAGES="pkg1;pkg2"

# 黑名单:跳过指定包

catkin_make -DCATKIN_BLACKLIST_PACKAGES="pkg3;pkg4"

五、环境配置命令

1. 设置环境变量

source devel/setup.bash # 临时设置当前终端的 ROS 环境变量

echo "source ~/catkin_ws/devel/setup.bash" >> ~/.bashrc # 永久设置

  • 验证echo $ROS_PACKAGE_PATH 应显示工作空间路径。
2. 检查环境信息前工作空间路径 catkin locate --shell-verbs # 显示环境设置命令

六、高级工具命令

1. 使用 catkin_tools(推荐替代方案)

安装

sudo apt install python3-catkin-tools

配置工作空间使用 catkin_tools

cd ~/catkin_ws

catkin config --init --mkdirs # 初始化配置

catkin build # 编译工作空间(替代 catkin_make)

  • 优势:并行编译速度更快,支持多配置管理。
2. 清理编译结果

catkin clean # 清理所有编译结果

catkin clean -b # 仅删除 build 目录

catkin clean -d # 仅删除 devel 目录

七、实战场景示例

1. 创建并编译新包

cd ~/catkin_ws/src catkin_create_pkg my_robot roscpp sensor_msgs

cd ~/catkin_ws catkin_make source devel/setup.bash

2. 仅更新特定包

修改了 my_package 后

cd ~/catkin_ws catkin_make --pkg my_package

3. 可视化依赖关系

cd ~/catkin_ws

catkin graph --dot > deps.dot

dot -Tpdf deps.dot -o deps.pdf

evince deps.pdf # 打开 PDF 查看依赖图

八、常见问题与解决

  1. 编译错误

    catkin_make -DCMAKE_BUILD_TYPE=Debug # 生成调试信息 catkin_make clean && catkin_make # 彻底重新编译

  2. 包找不到

    source devel/setup.bash # 刷新环境变量 catkin_make --force-cmake # 重新生成包索引

  3. 依赖冲突

    rosdep install --from-paths src --ignore-src -r -y # 自动安装依赖

九、总结

Catkin 命令是 ROS 开发的基础工具,掌握以下核心命令即可应对大多数场景:

  • 初始化 :catkin_init_workspace、catkin_create_pkg
  • 编译 :catkin_make、catkin build
  • 包管理 :catkin list、catkin graph
  • 环境配置 :source devel/setup.bash

建议结合 catkin_tools 工具提升开发效率,遇到问题时优先检查环境变量和依赖关系。

相关推荐
Cx330❀1 小时前
【Linux网络】一文吃透 TCP Socket 编程
linux·运维·服务器·开发语言·网络·tcp/ip
暖阳华笺1 小时前
【高频考点】回溯(暴力搜索)
数据结构·c++·算法·回溯法
hunterkkk(c++)1 小时前
学习dijkstra算法(c++)
c++·学习·算法
lightqjx2 小时前
【算法】数据结构_单调队列
数据结构·算法·单调队列
wb043072012 小时前
外卖大战——从阿明的“3 秒生死线“,看系统性能优化的全链路方法论
开发语言·性能优化·架构·php
小的~~2 小时前
Java线程及线程池的相关的问题
java·开发语言·多线程
c++之路2 小时前
Linux 下 C++ 开发环境搭建
linux·运维·c++
CTA终结者2 小时前
Python 写期货自动交易:行情下单与成交回报怎么组织
开发语言·python·区块链
小四季豆2 小时前
《数据结构与算法》-顺序表:算法落地的第一个线性结构
c语言·数据结构·算法