任务:
1,建立一个静态库和动态库,提供 HelloFunc 函数供其他程序编程使用,HelloFunc 向终端输出 Hello World 字符串。
2:安装头文件与共享库。
3.使用库
静态库和动态库的区别:
静态库的扩展名一般为“.a”或“.lib”;动态库的扩展名一般为“.so”或“.dll”。
静态库在编译时会直接整合到目标程序中,编译成功的可执行文件可独立运行
动态库在编译时不会放到连接的目标程序中,即可执行文件无法单独运行。
构建实例:
hello.h中的内容:
#ifndef HELLO_H
#define Hello_H
void HelloFunc();
#endif
hello.cpp中的内容:
#include "hello.h"
#include <iostream>
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,常见的使用方法: