CMake編譯中的庫文件和頭文件鏈接你了解嗎
外部庫文件、頭文件鏈接
指令
頭文件搜索路徑
INCLUDE_DIRECTORIES([AFTER|BEFORE] [SYSTEM] dir1 dir2 ...)
- [AFTER|BEFORE] :添加方式,默認
- AFTER AFTER:在后方進行追加內(nèi)容(新加入內(nèi)容在后)
- BEFORE:在前方進行追加內(nèi)容(新加入內(nèi)容在前)
- dir:頭文件路徑地址,含有空格的路徑應用雙引號括起
鏈接庫文件
LINK_DIRECTORIES(directory1 directory2 ...)
directory:庫文件名稱
該指令用于添加非標準共享庫搜索路徑。
TARGET_LINK_LIBRARIES(target library1 <debug | optimized> library2 ... )
target:被鏈接的對象library:庫名稱
實例
此處采用之前生成安裝好的庫文件libhello.so進行演示。
新建工程空間
首先,新建工程文件并定義工程CMakeLists.txt文件。
# 新建工程空間t4 mkdir -p ~/cmake_test/t4 cd ~/cmake_test/t4 # 新建子目錄src mkdir src # 新建工程CMakeLists.txt vim CMakeLists.txt
子目錄src用于存放源代碼,工程根目錄下的CMakeLists.txt內(nèi)容如下:
# 工程名 PROJECT(NEWHELLO) # 添加源碼目錄 ADD_SUBDIRECTORY(src)
定義src內(nèi)容
進入子目錄src,新建源文件main.cpp
# 進入src子目錄 cd ~/cmake_test/t4/src # 新建源文件 vim main.cpp
main.cpp文件內(nèi)容如下:
// main.cpp
#include <iostream>
using namespace std;
int main()
{
HelloFunc();
return 0;
}
源文件中調(diào)用了之前封裝的HelloFunc函數(shù),應將其頭文件及鏈接進行定義。在src目錄中新建CMakeLists.txt,其內(nèi)容如下:
# 添加頭文件搜索路徑 INCLUDE_DIRECTORIES(/usr/include/hello) # 添加鏈接 TARGET_LINK_LIBRARIES(main libhello.so) # 生成目標二進制文件 ADD_EXECUTABLE(main main.cpp)
上述語句,將動態(tài)庫libhello.so同main進行鏈接,并將頭文件加入搜索路徑中。此外,也可以選擇鏈接靜態(tài)庫libhello.a,只需將其修改為如下即可:
# 添加鏈接 TARGET_LINK_LIBRARIES(main libhello.a)
編譯
在t4根目錄中新建build子目錄用于編譯:
# 新建build子目錄 cd ~/cmake_test/t4 mkdir build & cd build # 構(gòu)建 cmake .. # 編譯 make -j12
此時,將在build/src中生成可執(zhí)行二進制文件main,運行該程序效果如下:
# 運行程序 cd ~/cmake_test/t4/build/src bash main # 程序輸出: Hello World
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!

