要让 C++ 项目用上 mold
链接器(号称比 lld 快 2–5 倍、比 GNU ld 快 10–30 倍的现代并行链接器),关键不是“替换命令”,而是让整个构建系统(CMake / Make / Bazel 等)真正识别并信任 mold,同时规避其当前对部分符号、插件和静态库的兼容性限制。
mold 目前仅支持 Linux(x86-64 / aarch64),不支持 macOS 或 Windows。安装后需确保:
– 可执行文件在 $PATH 中(如 /usr/local/bin/mold)
– 运行 mold --version 能正常输出(v2.0+ 推荐)
– 检查是否启用并行能力:mold --help | grep parallel(默认全核启用)
这是最稳妥、跨平台兼容的方式(无需改 toolchain 或重写 link rule):
CMakeLists.txt 顶层或 project() 后添加:if(CMAKE_SYSTEM_NAME STREQUAL "Linux")
find_program(MOLD_PATH NAMES mold)
if(MOLD_PATH)
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -fuse-ld=mold" CACHE STRING "")
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -fuse-ld=mold" CACHE STRING "")
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -fuse-ld=mold" CACHE STRING "")
endif()
endif()
set(CMAKE_LINKER mold) —— CMake 会跳过链接器参数传递,导致 -Wl,*, -static-libstdc++ 等失效mold 尚不支持:
– GNU linker scripts(.ld 文件)
– .so 内部 version script(-version-script)
– 某些 LTO 交互(尤其是 ThinLTO + mold 组合不稳定)
– 静态链接 libc++(建议优先用 libstdc++ 或动态链接)
__attribute__((visibility("hidden"))) + -fvisibility=hidden 替代 version script-flto=thin -fuse-ld=lld;非 LTO 构建再切回 moldif [ -n "$(mold --help 2>&1 | grep 'version-script')" ]; then ... else ...
启用 mold 后务必验证三项:
mold -t your_binary 查看段布局;nm -D your_binary | grep YourSymbol 确认导出正确time mold -o a.out ... vs time ld.lld -o a.out ...(排除磁盘缓存干扰,用 sync; echo 3 | sudo tee /proc/sys/vm/drop_caches)readelf -d a.out | grep NEEDED 和 ldd a.out 应与 lld 输出一致;函数地址偏移可差,但依赖关系不能少或多基本上就这些。mold 不是“设个 flag 就起飞”的黑盒,而是需要配合构建逻辑做轻量适配的加速组件——配置简单,但绕过边界条件才是工程落地的关键。