CmakeLists.txt文件相关编辑指令说明—C++

// 指定cmake的最低版本
cmake_minimum_required(VERSION 3.17)
// 寻找opencv库
find_package(OpenCV REQUIRED)
// 添加头文件
include_directories(${OpenCV_INCLUDE_DIRS})
// 打印显示相关信息
message(${OpenCV_INCLUDE_DIRS})
// 该指令的主要作用就是将指定的源文件生成链接文件,然后添加到工程中去。
add_library(<name> [STATIC | SHARED | MODULE]
            [EXCLUDE_FROM_ALL]
            [source1] [source2] [...])
# 编译产生链接库,我这里产生的是动态链接库
add_library(${PROJECT_NAME} SHARED
      src/China.cpp
      src/i.cpp
      src/love.cpp
)

add_library()说明:其中表示库文件的名字,该库文件会根据命令里列出的源文件来创建。而STATIC、SHARED和MODULE的作用是指定生成的库文件的类型。STATIC库是目标文件的归档文件,在链接其它目标的时候使用。SHARED库会被动态链接(动态链接库),在运行时会被加载。MODULE库是一种不会被链接到其它目标中的插件,但是可能会在运行时使用dlopen-系列的函数。默认状态下,库文件将会在于源文件目录树的构建目录树的位置被创建,该命令也会在这里被调用。

// 设置 YAML_LIB_DIR 作为  ./depends/yaml-cpp/libs 的变量名
set(YAML_LIB_DIR ./depends/yaml-cpp/libs)
link_directories(${YAML_LIB_DIR})

link_directories() 说明:该指令的作用主要是指定要链接的库文件的路径,该指令有时候不一定需要。因为find_package和find_library指令可以得到库文件的绝对路径。不过你自己写的动态库文件放在自己新建的目录下时,可以用该指令指定该目录的路径以便工程能够找到,如上面的例子yaml-cpp/libs 就是自己写的文件生成的动态库文件,不是从系统中寻找的。

// 生成可执行文件,imageprocess为生成的可执行文件的名称,可以使用任意名字。
add_executable(imageprocess pengzhangfushi.cpp)
// 该指令的作用为将目标文件与库文件进行链接。该指令的语法如下:
target_link_libraries(<target> [item1] [item2] [...]
                      [[debug|optimized|general] <item>] ...)
//  链接opencv库到要生成的可执行文件imageprocess上
// target_link_libraries() 可以从系统系统中找到相关库。
// 而 link_directories() 是寻找从自己新建的目录下的动态库文件。
target_link_libraries(imageprocess  ${OpenCV_LIBS})

target_link_libraries()说明:上述指令中的target是指通过add_executable()和add_library()指令生成已经创建的目标文件。而[item]表示库文件没有后缀的名字。默认情况下,库依赖项是传递的。当这个目标链接到另一个目标时,链接到这个目标的库也会出现在另一个目标的连接线上。这个传递的接口存储在interface_link_libraries的目标属性中,可以通过设置该属性直接重写传递接口。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值