4.CMakeList创建静态库和动态库

参考视频:https://www.bilibili.com/video/BV1vR4y1u77h?p=5
笔记链接: https://pan.baidu.com/s/1ue-p3Eum9pnPlJoPYhNLpg 提取码: nf2c
任务:
1,建立一个静态库和动态库,提供 HelloFunc 函数供其他程序编程使用,HelloFunc 向终端输出 Hello World 字符串。
2:安装头文件与共享库。
3.使用库
静态库和动态库的区别:
静态库的扩展名一般为“.a”或“.lib”;动态库的扩展名一般为“.so”或“.dll”。
静态库在编译时会直接整合到目标程序中,编译成功的可执行文件可独立运行
动态库在编译时不会放到连接的目标程序中,即可执行文件无法单独运行。

构建实例:
4.CMakeList创建静态库和动态库_第1张图片
hello.h中的内容:

#ifndef HELLO_H
#define Hello_H
void HelloFunc();
#endif

hello.cpp中的内容:

#include "hello.h"
#include 
void HelloFunc(){
std::cout << "Hello World" << std::endl;
}

项目中的CMakeList内容:

PROJECT(HELLO)
ADD_SUBDIRECTORY(lib bin)#bin为库文件输出路径

/lib/CMakeList内容

SET(LIBHELLO_SRC hello.cpp)
ADD_LIBRARY(hello_static STATIC ${LIBHELLO_SRC})
#对hello_static的重名为hello
SET_TARGET_PROPERTIES(hello_static PROPERTIES OUTPUT_NAME "hello")
#cmake 在构建一个新的target 时,会尝试清理掉其他使用这个名字的库,因为,在构建 libhello.so 时, 就会清理掉 libhello.a
SET_TARGET_PROPERTIES(hello_static PROPERTIES CLEAN_DIRECT_OUTPUT 1)
ADD_LIBRARY(hello SHARED ${LIBHELLO_SRC})
#动态库
SET_TARGET_PROPERTIES(hello PROPERTIES OUTPUT_NAME "hello")
SET_TARGET_PROPERTIES(hello PROPERTIES CLEAN_DIRECT_OUTPUT 1)

语法说明:
ADD_LIBRARY
ADD_LIBRARY(hello SHARED ${LIBHELLO_SRC})
hello:就是正常的库名,生成的名字前面会加上lib,最终产生的文件是libhello.so
SHARED,动态库 STATIC,静态库
${LIBHELLO_SRC} :源文件

SET_TARGET_PROPERTIES
这条指令可以用来设置输出的名称,对于动态库,还可以用来指定动态库版本和 API 版本

动态库的版本号
一般动态库都有一个版本号的关联

libhello.so.1.2
libhello.so ->libhello.so.1
libhello.so.1->libhello.so.1.2

CMakeLists.txt 插入如下

SET_TARGET_PROPERTIES(hello PROPERTIES VERSION 1.2 SOVERSION 1)

VERSION 指代动态库版本,SOVERSION 指代 API 版本

安装共享库和头文件
本例中我们将 hello 的共享库安装到/lib目录,
将 hello.h 安装到/include/hello 目录
静态库安装到lib目录
在/CMakeList添加

#文件放到该目录下
INSTALL(FILES hello.h DESTINATION include/hello)
#二进制,静态库,动态库安装都用TARGETS
#ARCHIVE 特指静态库,LIBRARY 特指动态库,RUNTIME 特指可执行目标二进制。
INSTALL(TARGETS hello hello_static LIBRARY DESTINATION lib ARCHIVE DESTINATION lib)

注意:
安装的时候,指定一下路径,放到系统下

cd build
#..表示上一级
cmake -DCMAKE_INSTALL_PREFIX=/usr ..
make
make install

最终安装位置
hello.h 安装到usr/include/hello 目录
静态库动态库安装到usr/lib目录
CMAKE_INSTALL_PREFIX命令,设定使用install命令安装的目标路径
CMAKE_INSTALL_PREFIX变量,类似于configure脚本的 –prefix,常见的使用方法:

你可能感兴趣的:(#,编译,自动驾驶,人工智能,机器学习)