target_link_options 指令用于为指定的目标设置链接器选项。通过这些选项,你可以控制链接过程中的各种参数,从而影响目标的链接行为。
语法
target_link_options(<target> [INTERFACE|PUBLIC|PRIVATE] <options>...)
- target: 要应用这些链接选项的目标,通常是通过 add_executable 或 add_library 定义的目标。
- INTERFACE: 链接选项将仅应用于使用此目标的其他目标,不会应用于该目标本身。通常用于库的公共 API。
- PUBLIC: 链接选项将应用于该目标及所有链接到该目标的目标。适用于库的公共部分和使用该库的可执行文件或其他库。
- PRIVATE: 链接选项将仅应用于该目标,不会传播给其他依赖于该目标的目标。
示例
- 为目标添加私有链接选项:
add_executable(my_executable main.cpp)# Add a linker option for this target
target_link_options(my_executable PRIVATE -Wl,--no-as-needed)
在这个例子中,-Wl,–no-as-needed 选项将仅应用于 my_executable 目标,影响链接器的行为。
- 公共链接选项:
add_library(my_library my_library.cpp)
target_link_options(my_library PUBLIC -static)add_executable(my_executable main.cpp)
target_link_libraries(my_executable my_library)
在这个例子中,-static 链接选项不仅应用于 my_library,还会传递到所有链接到 my_library 的目标中,例如 my_executable。
- 接口链接选项:
add_library(my_library INTERFACE)
target_link_options(my_library INTERFACE -lboost_system)add_executable(my_executable main.cpp)
target_link_libraries(my_executable my_library)
这里,my_library 是一个接口库,它本身不链接任何库,但 -lboost_system 选项会传递给所有链接到 my_library 的目标,即 my_executable。
使用场景
- 控制链接器行为: 设置特定的链接器选项,例如 -Wl,–no-as-needed 以控制共享库的链接行为。
- 静态或动态链接: 强制链接静态库或动态库,如使用 -static 或 -shared。
- 指定链接库: 添加额外的链接库或链接器脚本,如使用 -L 和 -l 选项。
注意事项
- target_link_options 是 CMake 3.13 及更高版本中引入的指令。对于旧版本的 CMake,通常使用LINK_FLAGS 属性来设置链接器选项,但这可能不会完全支持所有目标链接需求。
- 链接选项可能会影响整个链接过程,因此使用时要小心,以确保它们不会干扰其他目标的链接行为。
通过 target_link_options,你可以详细控制每个目标的链接选项,确保构建过程符合你的要求。