溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何正確的使用CMake

發(fā)布時間:2021-03-10 13:53:35 來源:億速云 閱讀:202 作者:Leah 欄目:開發(fā)技術(shù)

如何正確的使用CMake?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

CMake是一個比make更高級的編譯配置工具,它可以根據(jù)不同平臺、不同的編譯器,生成相應(yīng)的Makefile。通過編寫CMakeLists.txt,可以控制生成的Makefile,從而控制編譯過程。CMake自動生成的Makefile不僅可以通過make命令構(gòu)建項(xiàng)目,生成目標(biāo)文件,還支持安裝(make install)、測試安裝的程序是否能正確執(zhí)行(make test,或者ctest)、生成當(dāng)前平臺的安裝包(make package)、生成源碼包(make package_source)、產(chǎn)生Dashboard顯示數(shù)據(jù)并上傳等高級功能,只要在CMakeLists.txt中簡單配置,就可以完成很多復(fù)雜的功能,包括寫測試用例。如果有嵌套目錄,子目錄下可以有自己的CMakeLists.txt。

  在 linux 平臺下使用 CMake 生成 Makefile 并編譯的流程如下:

  1. 編寫 CMake 配置文件 CMakeLists.txt 。

  2. 執(zhí)行命令 cmake PATH 或者 ccmake PATH 生成 Makefile。其中, PATH 是 CMakeLists.txt 所在的目錄。

  3. 使用 make 命令進(jìn)行編譯。

語法

  CMake基本語法由命令、注釋和空格組成,其中命令是不區(qū)分大小寫的。符號 # 后面的內(nèi)容被認(rèn)為是注釋。命令由命令名稱、小括號和參數(shù)組成,參數(shù)之間使用空格進(jìn)行間隔。變量引用使用 ${VAR} 形式。

  command (args  ...)  #comment

常用命令:

    cmake_minimum_required (VERSION 2.8)  # CMake 最低版本號要求

  project (Demo)               # 指定項(xiàng)目的名稱

  set(SRCS main.cpp ...)             # 設(shè)置變量

  include_directories(/usr/include/jsoncpp)        # 添加頭文件目錄,比如使用的一些lib庫

  aux_source_directory(. DIR_SRCS)     # 查找當(dāng)前目錄下的所有源文件,并將名稱保存到 DIR_SRCS 變量

  add_subdirectory(math)           # 添加 math 子目錄

  add_executable(Demo main.cc ...)       # 指定生成目標(biāo),第一個參數(shù)為目標(biāo)文件名

  add_library(MathFunctions ${DIR_LIB_SRCS})   # 添加一個庫文件

  target_link_libraries(Demo MathFunctions)    # 添加鏈接庫

獲取更多CMake信息:

  cmake --help

  cmake --help-command-list

  cmake --help-variable-list

示例代碼

示例代碼1:

cmake_minimum_required(VERSION 2.8)    # CMake 最低版本號要求

set(CMAKE_CXX_FLAGS "-std=c++0x")      # 設(shè)置編譯參數(shù)
include_directories(/usr/include/jsoncpp) # 添加頭文件目錄

set(SRCS                     # 設(shè)置變量SRCS,將所有源文件添加到變量SRCS
  SamsungRequestResolver.cpp
  SamsungResolverContainer.cpp
  SamsungResponseResolver.cpp
  BanCat.cpp
  main.cpp
)

add_executable(framework ${SRCS})     # 指定生成目標(biāo)
target_link_libraries(framework jsoncpp hiredis boost_system)  # 添加鏈接庫

示例代碼2:(來源于參考引用1)

代碼目錄如下所示,./Demo3目錄下有一個main.cc文件和一個math目錄。對于這種嵌套目錄的情況,需要在目錄 ./Demo3 和 ./Demo3/math 下各創(chuàng)建一個CMakeLists.txt。

./Demo3
  |
  +--- main.cc
  |
  +--- math/
     |
     +--- MathFunctions.cc
     |
     +--- MathFunctions.h

父目錄中的 CMakeLists.txt :

# CMake 最低版本號要求
cmake_minimum_required (VERSION 2.8)
# 項(xiàng)目信息
project (Demo3)
# 查找當(dāng)前目錄下的所有源文件
# 并將名稱保存到 DIR_SRCS 變量
aux_source_directory(. DIR_SRCS)
# 添加 math 子目錄,math目錄下的CMakeLists.txt文件和源代碼會被處理
add_subdirectory(math)
# 指定生成目標(biāo)Demo
add_executable(Demo main.cc)
# 添加鏈接庫
target_link_libraries(Demo MathFunctions)

子目錄中的 CMakeLists.txt:

 # 查找當(dāng)前目錄下的所有源文件
 # 并將名稱保存到 DIR_LIB_SRCS 變量
 aux_source_directory(. DIR_LIB_SRCS)
 # 生成鏈接庫
 add_library(MathFunctions ${DIR_LIB_SRCS})

編譯

  在編譯之前,首先要將CMakeLists.txt文件放在代碼目錄中。為了方便管理生成的makefile文件、目標(biāo)文件等文件,最好創(chuàng)建一個build目錄專門用來存放這些文件。在代碼目錄,依次執(zhí)行以下命令:

mkdir build
cd build
cmake ..
make

關(guān)于如何正確的使用CMake問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI