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)容!