CMakeLists.txt的基本结构
编写 CMakeLists.txt
最常用的功能就是调用其他的.h头文件和.so/.a库文件,将.cpp/.c/.cc文件编译成可执行文件或者新的库文件。
命令的官方网站:CMake Reference Documentation
最常用的命令如下(仅供后期查询,初期不需要细看):
cmake_minimum_required(VERSION 3.15) # 指定cmake最低版本
project(mkfile) # 指定项目名
# 搜索CMakeLists.txt目录下的所有源文件并赋值给SRC 推荐
aux_source_directory(${PROJECT_SOURCE_DIR} SRC)
# 搜索CMakeLists目录下的所有源文件并赋值给SRC
file(GLOB SRC ${CMAKE_CURRENT_SOURCE_DIR}/*.cpp)
# 设置可执行文件的输出路径
set(EXECUTABLE_OUTPUT_PATH /home/zhudejian/workspace/mkfile)
set(CMAKE_CXX_STANDARD 11) # 指定c++11
add_executable(app ${SRC}) # 生成可执行文件
include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include) # 指定头文件路径
#生成动态库和静态库
add_library(calc SHARED ${SRC}) # calc 是动态库名 libcalc.so
# add_library(calc STATIC ${SRC}) # 生成 libcalc.a
# 设置库文件的输出路径
set(LIBRARY_OUTPUT_PATH /home/zhudejian/workspace/v3/dong_lib)
# 要链接库文件的路径 链接静态库
link_directories(${CMAKE_CURRENT_SOURCE_DIR}/onnx1/lib)
link_libraries(calc) # 链接静态库
# 链接动态库 --- 要放在生成可执行文件之后
link_directories(${CMAKE_CURRENT_SOURCE_DIR}/dong_lib)
add_executable(app ${SRC})
target_link_libraries(app calc) # 链接动态库
# 打印日志信息message
message("xxxxxxxxxxxxxxxxxxxxxxxx")
message(STATUS "************************") # 一般消息
# message(FATAL_ERROR "1111111******") # 重要错误,程序执行到这里会中断
# 字符串拼接
set(temp hello world)
set(re ${SRC} ${temp})
message(${re})
# 字符串追加
list(APPEND temp "xxx" "***" "111") # 在temp后面追加三个子字符串
message(${temp})
# 在指定字符串中删除一部分数据
list(REMOVE_ITEM SRC /home/zhudejian/workspace/v3/main.cpp)