导航

  • 索引
  • 下一个 |
  • 上一个 |
  • CMake 标志 CMake 4.0.0 »
  • 文档 »
  • cmake-variables(7) »
  • CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES

CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES¶

在 3.30 版本中添加。

此变量定义了指定链接库 <FEATURE> 的行为。它指定了 <FEATURE> 如何与其他特性交互,<FEATURE> 何时应该应用,以及当 CMake 组装最终链接器命令行时,应如何处理 <FEATURE> 的各个方面(例如,去重)。

用于 <FEATURE> 的链接器标志的语法由 CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE> 和 CMAKE_LINK_LIBRARY_USING_<FEATURE> 变量控制。CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE>_SUPPORTED 和 CMAKE_LINK_LIBRARY_USING_<FEATURE>_SUPPORTED 变量控制 <FEATURE> 是否可用。

当为特定语言 <LANG> 链接时,如果为相同的 <FEATURE> 也定义了 CMAKE_<LANG>_LINK_LIBRARY_<FEATURE>_ATTRIBUTES 变量,则 CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES 将被忽略。

在定义目标的目录作用域末尾,CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES 和 CMAKE_<LANG>_LINK_LIBRARY_<FEATURE>_ATTRIBUTES 的值才是重要的。

特性属性定义¶

特性属性定义是 分号分隔的列表,其中包含 attribute=value(s) 项。如果一个属性有多个值,这些值必须用逗号分隔。

支持以下属性

LIBRARY_TYPE=<library-type-list>

指定特性支持的库类型。支持的值包括:STATIC,SHARED,MODULE 和 EXECUTABLE。

如果未指定此属性,则默认值为 LIBRARY_TYPE=STATIC,SHARED,MODULE,EXECUTABLE。

如果该特性与不支持的库类型一起使用,CMake 将发出开发者警告,并且该特性将被忽略。

OVERRIDE=<feature-list>

指定在发生冲突时,此特性替换哪些特性。如果定义了 LINK_LIBRARY_OVERRIDE 或 LINK_LIBRARY_OVERRIDE_<LIBRARY> 目标属性定义,则此覆盖机制将被它们取代。

如果未指定此属性,则默认为空列表。

DEDUPLICATION=YES|NO|DEFAULT

指定使用此特性的库的去重策略。

YES

库始终去重。CMake 通常应用的默认策略将被忽略。

NO

库永不去重。CMake 通常应用的默认策略将被忽略。

DEFAULT

让 CMake 自动确定去重策略。

如果未指定此属性,将使用 DEFAULT。

示例¶

一个常见的需求是在创建共享库时加载完整的归档文件。内置的 WHOLE_ARCHIVE 特性可以用于此目的。该内置特性的实现设置了以下链接库特性属性

set(CMAKE_LINK_LIBRARY_WHOLE_ARCHIVE_ATTRIBUTES
  LIBRARY_TYPE=STATIC
  OVERRIDE=DEFAULT
  DEDUPLICATION=YES
)
LIBRARY_TYPE=STATIC

此特性仅对静态库有意义。

OVERRIDE=DEFAULT

DEFAULT 特性将被 WHOLE_ARCHIVE 特性覆盖,因为它们是兼容的,并且可以增强用户体验:标准库规范和 $<LINK_LIBRARY:WHOLE_ARCHIVE> 可以自由使用。

DEDUPLICATION=YES

当使用此特性时,链接器会从静态库中加载所有符号,因此无需在链接器命令行中重复该库。

WHOLE_ARCHIVE 特性可以像这样使用

add_library(A STATIC ...)
add_library(B STATIC ...)

target_link_libraries(B PUBLIC A)
target_link_libraries(A PUBLIC B)

add_library(global SHARED ...)
target_link_libraries(global PRIVATE $<LINK_LIBRARY:WHOLE_ARCHIVE,A>)

生成的链接命令将只指定库 A 的一个实例,并且链接器标志将确保从库 A 加载所有符号。

目录

  • CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES
    • 特性属性定义
    • 示例

上一个主题

CMAKE_LINK_LIBRARIES_STRATEGY

下一个主题

CMAKE_LINK_LIBRARY_FILE_FLAG

本页

  • 显示源代码

快速搜索

导航

  • 索引
  • 下一个 |
  • 上一个 |
  • CMake 标志 CMake 4.0.0 »
  • 文档 »
  • cmake-variables(7) »
  • CMAKE_LINK_LIBRARY_<FEATURE>_ATTRIBUTES
© 版权所有 2000-2025 Kitware, Inc. 和贡献者。使用 Sphinx 7.3.7 创建。