也许每个人都像永恒一样,我们每个人都不想等待很长时间才能完成项目组装。如果工作时间很长,那么您可以喝杯咖啡来消磨时间,讨论自动垃圾收集的所有缺点。
有时,通过执行CMake优化可以取得一定的成功。这里考虑的技术基于一个简单的想法:可以同时组装使用彼此功能的两个静态库。
有点解剖
首先,请考虑构建静态库的基本步骤:
- 预处理器 -从源文件中删除所有注释,插入头文件,并将宏替换为计算出的值。
- 编译器 -将预处理器处理的文件转换为汇编代码。
- 汇编程序 -将汇编代码转换为机器代码;结果保存为目标文件。
- 存档器 -将目标文件收集到单个存档中。
这些步骤以图形方式显示在图中:
, . , . . , , .
, , CMake target_link_libraries. :
target_link_libraries(staticC PRIVATE staticB)
, — staticC staticB. , , , staticC, staticB.
, CoherentDeps, :
, staticC staticB, .
, , , ( , ) INTERFACE, -meta ( , ). , -, .
target_link_libraries .
, :
: NonCoherentDeps.
:
NonCoherentDeps.
staticB staticA, staticC staticB, NonCoherentDeps staticC. :
CMake- staticA - :
add_library(staticA-meta INTERFACE)
target_include_directories(staticA-meta INTERFACE "${CMAKE_CURRENT_SOURCE_DIR}")
, :
target_link_libraries(staticA PUBLIC staticA-meta)
staticB CMake
target_link_libraries(staticB PRIVATE staticA)
:
target_link_libraries(staticB PRIVATE staticA-meta)
staticA staticB, . staticB staticA .
:
— :
add_executable(NonCoherentDeps main.cpp)
target_link_libraries(NonCoherentDeps PRIVATE staticC staticB staticA )
, .
, staticA, target_include_directories. NonCoherentDeps, :
target_include_directories(staticB PRIVATE "${path_to_headers_in_staticA}")
:
target_link_libraries(staticB PRIVATE staticA-meta)
, staticB staticA, staticC :
target_include_directories(staticC PRIVATE "${path_to_headers_in_staticB}" "${path_to_headers_in_staticA}")
. :
target_link_libraries(staticB-meta INTERFACE staticA-meta)
staticC :
target_link_libraries(staticC INTERFACE staticB-meta)
staticB, , .
同样,在元软件包中,您可以以命令的形式添加依赖项以生成头文件,并且属性是正确的路径。