cmake学习笔记之add_library、target_link_libraries和link_directories

cmake学习笔记之add_library、target_link_libraries和link_directories

博文转自:https://blog.csdn.net/bigdog_1027/article/details/79113342

cmake是Linux(这里默认是Ubuntu系统)下常使用的编译C++的工具,而使用cmake就需要先在CmakeLists.txt文件中对编译规则进行。这里介绍常用的三种指令add_library、target_link_libraries和link_directories,该笔记主要参考了cmake官网给的教程,如有需要请访问以下网址:

https://cmake.org/cmake/help/v3.1/

1. add_library

该指令的主要作用就是将指定的源文件生成链接文件,然后添加到工程中去。该指令常用的语法如下:

add_library(<name> [STATIC | SHARED | MODULE]
            [EXCLUDE_FROM_ALL]
            [source1] [source2] [...])

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

例子:
add_library例子

2. link_directories

该指令的作用主要是指定要链接的库文件的路径,该指令有时候不一定需要。因为find_package和find_library指令可以得到库文件的绝对路径。不过你自己写的动态库文件放在自己新建的目录下时,可以用该指令指定该目录的路径以便工程能够找到。

link_directories(
    lib
)

3. target_link_libraries

该指令的作用为将目标文件与库文件进行链接。该指令的语法如下:

target_link_libraries(<target> [item1] [item2] [...]
                      [[debug|optimized|general] <item>] ...)

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

例子如下:
在这里插入图片描述

参考博客

https://www.cnblogs.com/coderfenghc/archive/2012/06/23/2559603.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
add_libraryCMake中的一个指令,用于将源文件编译成库文件。它的语法如下: ```cmake add_library(<name> [STATIC | SHARED | MODULE] [EXCLUDE_FROM_ALL] source1 [source2 ...]) ``` 其中,name是库文件的名称,可以是任意字符串;STATIC、SHARED和MODULE是可选参数,用于指定库文件的类型,默认为STATIC;EXCLUDE_FROM_ALL是可选参数,用于指定该库文件是否被包含在ALL选项中,默认为不包含;source1、source2等是源文件的路径。 find_libraryCMake中的一个指令,用于查找指定的库文件。它的语法如下: ```cmake find_library(<VAR> name1 [path1 path2 ...]) ``` 其中,VAR是一个变量,用于存储找到的库文件的路径;name1是要查找的库文件的名称;path1、path2等是可选参数,用于指定查找库文件的路径。 target_link_librariesCMake中的一个指令,用于将目标文件与库文件进行链接。它的语法如下: ```cmake target_link_libraries(<target> [item1] [item2] [...]) ``` 其中,target是通过add_executable()和add_library()指令生成的目标文件;item1、item2等是要链接的库文件的名称。 以下是一个示例,演示了如何使用add_library、find_librarytarget_link_libraries指令: ```cmake # 添加一个名为mylib的库文件 add_library(mylib SHARED mylib.cpp) # 查找名为mylib的库文件 find_library(MYLIB_LIB mylib) # 添加一个名为myapp的可执行文件,并将其与mylib库文件进行链接 add_executable(myapp main.cpp) target_link_libraries(myapp ${MYLIB_LIB}) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值