cmake之ADD_LIBRARY()
上⼀篇我分析了如何调⽤别⼈的第三⽅库,现在我继续分析如何构建⼀个库供他⼈使⽤。完成这个任务需要⽤到ADD_LIBRARY()
强烈建议学习cmake的同学多多参考官⽅⽂档,⾃⼰也是参考了⼀部分。cmake如何使用
1:ADD_LIBRARY()语法
add_library(<name> [STATIC | SHARED | MODULE]
[EXCLUDE_FROM_ALL]
source1 [source2 ...])
<name> :库的名字,直接写名字即可,不要写lib,会⾃动加上前缀的哈。
[STATIC | SHARED | MODULE] :类型有三种。
SHARED,动态库
STATIC,静态库
MODULE,在使⽤ dyld 的系统有效,如果不⽀持 dyld,则被当作 SHARED 对待。
EXCLUDE_FROM_ALL:这个库不会被默认构建,除⾮有其他的组件依赖或者⼿
⼯构建。
2:使⽤
SET(LIBHELLO_SRC hello.c)
ADD_LIBRARY(hello SHARED ${LIBHELLO_SRC})
ADD_LIBRARY(hello_static STATIC ${LIBHELLO_SRC})
3:注意,⼀般我们使⽤的静态库/动态库只是后缀名不同⽽已,上⾯构建的libhello.so与libhello_static.a,显然名字不同哦。这时你会有⼀个想法,那我把hello_static改成hello,结果是不可⾏的,静态库⽆法构建。重名会忽略第⼆条指令。
解决⽅法:改libhello_static.a的属性–输出名字
SET_TARGET_PROPERTIES(hello_static PROPERTIES OUTPUT_NAME "hello")
这样就可以⽣成libhello.so与libhello.a了
4:关于动态库的版本号
#VERSION 指代动态库版本,SOVERSION 指代 API 版本。
SET_TARGET_PROPERTIES(hello PROPERTIES VERSION 1.2 SOVERSION 1)
从中我们可以看出:不管你的动态库版本是什么,对外调⽤总是libxxx.so。