news 2026/4/23 15:27:48

colcon build 与 colcon build --symlink-install

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
colcon build 与 colcon build --symlink-install

通俗点说,--symlink-install是一个**“帮你偷懒、提高效率”**的神器。

它的核心作用是:把“复制文件”变成“创建快捷方式”。


1. 如果不加这个参数 (普通模式)

  • 动作:colcon会把你写的代码(比如 Python 脚本、Launch 启动文件、YAML 配置文件)从src目录完整复制一份到install目录里。

  • 后果:

    • 如果你修改了src里的代码。

    • 你运行程序时,ROS 运行的是install里的旧副本

    • 你必须再次运行colcon build,把新代码重新复制过去,修改才会生效。

  • 缺点:改一行代码就要编译一次,非常浪费时间。

2. 加了这个参数 (--symlink-install)

  • 动作:colcon不会复制文件,而是会在install目录里创建一个指向src目录的软链接 (Symbolic Link,相当于 Windows 的快捷方式)

  • 后果:

    • 你修改了src里的代码。

    • 你运行程序时,ROS 顺着快捷方式直接找到了你刚改完的新代码

    • 不需要重新编译,直接运行就能看到效果!

  • 优点:改完代码直接跑,效率起飞。


⚠️ 重要区分:对不同语言的效果

虽然它很好用,但它不是万能的,对 Python 和 C++ 的效果不同:

文件类型加了参数后的效果是否需要重新编译?
Python 代码(.py)实时生效不需要(改完直接运行)
配置文件(.yaml,.xml)实时生效不需要
启动文件(.launch.py)实时生效不需要
C++ 代码(.cpp)无效必须编译(因为 C++ 需要编译成二进制文件,光有快捷方式没用)
C++ 头文件(.hpp)部分生效通常还是建议编译

部分包编译:

场景 A:我刚开机,或者拉取了别人的新代码(全部重新编译)

当你不知道别人改了哪里,或者你想确保整个系统没问题时:

cd ~/work_space/lubo_auto_car colcon build --symlink-install source install/setup.bash
场景 B:我只改了自己的某个包(增量编译)

比如你只改了planning_node的代码,编译所有包太慢了(尤其是以后包多了之后)。只编译一个包(省时间):

# 语法:--packages-select 包名 colcon build --symlink-install --packages-select planning_node ​ # 别忘了编译完刷新环境 source install/setup.bash
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 6:43:18

网络安全学习路线(超详细版):从零基础到精通,一篇吃透不迷路

在当今数字化时代,网络安全的重要性日益凸显。越来越多的人对网络安全产生了浓厚的兴趣,并希望通过自学来掌握这一领域的知识和技能。本文将为大家介绍网络安全自学的四个阶段,帮助大家系统地学习网络安全知识。 一、基础入门阶段 1、学习目…

作者头像 李华
网站建设 2026/4/23 12:53:31

【计算机毕设】城市智能交通大数据研判系统

💟博主:程序员小俊:CSDN作者、博客专家、全栈领域优质创作者 💟专注于计算机毕业设计,大数据、深度学习、Java、小程序、python、安卓等技术领域 📲文章末尾获取源码数据库 🌈还有大家在毕设选题…

作者头像 李华
网站建设 2026/4/23 14:11:36

AI应用开发热潮下,Java企业如何破解多模型接入困局?

在人工智能技术全面渗透的当下,AI应用开发已经成为企业数智化转型的核心抓手。无论是智能问答、知识库构建,还是业务流程自动化,接入AI大模型、Embedding模型与向量数据库,都是开启AI应用开发的第一步。对于长期深耕Java技术栈的企…

作者头像 李华
网站建设 2026/4/23 14:46:39

LangChain入门(十三)- 6步实操Agent落地大法

前言过去几年,大模型和 Agent 的讨论铺天盖地,但多数团队卡在同一个问题上:知道 Agent 很强,却不知道第一步该写什么代码。产品经理画了流程图,工程师接了 API,结果跑起来发现 AI 根本理解不了用户意图&…

作者头像 李华
网站建设 2026/4/23 11:49:05

uniapp+python博物馆知识科普分享服务平台 微信小程序

目录项目概述技术架构核心功能创新点应用场景开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!项目概述 Uniapp结合Python开发的博物馆知识科普分享服务平台微信小程序,旨在通过移…

作者头像 李华