CMake - 构建和链接静态库和动态库

一、准备代码

1. main.cpp

#include "Message.hpp"
#include <cstdlib>
#include <iostream>

int main() {
	Message say_hello("Hello, CMake World!");
	std::cout << say_hello << std::endl;

  	Message say_goodbye("Goodbye, CMake World");
  	std::cout << say_goodbye << std::endl;
  
  	return EXIT_SUCCESS;
}

2. Message.hpp

#pragma once

#include <iosfwd>
#include <string>

class Message {
public:
  Message(const std::string &m) : message_(m) {}
  friend std::ostream &operator<<(std::ostream &os, Message &obj) {
    return obj.printObject(os);
  }
  
private:
  std::string message_;
  std::ostream &printObject(std::ostream &os);
};

3. Message.cpp

#include "Message.hpp"
#include <iostream>
#include <string>

std::ostream &Message::printObject(std::ostream &os) {
  os << "This is my very nice message: " << std::endl;
  os << message_;
  return os;
}

二、CMakeLists.txt

1. 静态库CMakeLists.txt

cmake_minimum_required(VERSION 3.10 FATAL_ERROR)
project(sample_002 LANGUAGES CXX)

# 第二个参数 STATIC 表示把 Message.cpp和Message.hpp编译成静态库
add_library(message
    STATIC
    Message.hpp
    Message.cpp
    )

add_executable(hello-world main.cpp)

target_link_libraries(hello-world message)

2. 动态库CMakeLists.txt

cmake_minimum_required(VERSION 3.10 FATAL_ERROR)
project(sample_002 LANGUAGES CXX)

# 第二个参数 SHARED 表示把 Message.cpp和Message.hpp编译成动态库
add_library(message
    SHARED
    Message.hpp
    Message.cpp
    )

add_executable(hello-world main.cpp)

target_link_libraries(hello-world message)

3. BUILD_SHARED_LIBS

cmake_minimum_required(VERSION 3.10 FATAL_ERROR)
project(sample_002 LANGUAGES CXX)

# 是否编译动态库,与add_library的第二个参数有关,添加此变量后,add_library第二个参数可省略
# 当设置为 OFF 时, 编译成静态库
# 当设置为 ON 时,编译成动态库
set(BUILD_SHARED_LIBS OFF)

add_library(message
    Message.hpp
    Message.cpp
    )

add_executable(hello-world main.cpp)

target_link_libraries(hello-world message)

三、编译运行

mkdir -p build
cd build
cmake ..
cmake --build .
./hello-world

四、总结

  1. add_library(message STATIC Message.hpp Message.cpp):生成静态库libmessage.a
  2. add_library(message SHARED Message.hpp Message.cpp):生成动态库libmessage.so
  3. 静态库和动态库主要区别在add_library的第二个参数(此参数缺省等同于STATIC):
    参数值说明
    STATIC用于创建静态库,即编译文件的打包存档,以便在链接其他目标时使用
    HARED用于创建动态库,即可以动态链接,并在运行时加载的库
    OBJECT可将给定add_library的列表中的源码编译到目标文件,不将它们归档到静态库中,也不能将它们链接到共享对象中
    MODULE又为DSO组。与SHARED库不同,它们不链接到项目中的任何目标,不过可以进行动态加载。该参数可以用于构建运行时插件
  4. target_link_libraries(hello-world message):将libmessage库链接到可执行文件hello-world中;
  5. target_link_libraries命令还确保hello-world可执行文件可以正确地依赖于消息库。因此,在消息库libmessage链接到hello-world可执行文件之前,需要完成消息库libmessage的构建
  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要使用 CMake 编译动态库静态库,你可以按照以下步骤进行操作: 1. 创建一个 CMakeLists.txt 文件,该文件描述了构建过程和项目配置。 2. 在 CMakeLists.txt 文件中,使用 `add_library` 命令来定义要构建的库。使用 `SHARED` 参数来指定动态库,使用 `STATIC` 参数来指定静态库。例如: ```cmake # 构建动态库 add_library(mylib SHARED src/mylib.cpp) # 构建静态库 add_library(mylib_static STATIC src/mylib.cpp) ``` 3. 如果你有多个源文件,可以将它们一起添加到库中: ```cmake # 构建动态库 add_library(mylib SHARED src/mylib.cpp src/other.cpp) # 构建静态库 add_library(mylib_static STATIC src/mylib.cpp src/other.cpp) ``` 4. 如果你想为库定义公共头文件目录,可以使用 `target_include_directories` 命令。例如: ```cmake target_include_directories(mylib PUBLIC include) ``` 5. 如果你希望链接其他库到你的库中,可以使用 `target_link_libraries` 命令。例如: ```cmake target_link_libraries(mylib PUBLIC otherlib) ``` 6. 最后,在 CMakeLists.txt 文件中添加一个 `install` 命令,以便在构建过程完成后安装库文件到指定的目录。例如: ```cmake install(TARGETS mylib DESTINATION lib) install(FILES include/mylib.h DESTINATION include) ``` 7. 运行 CMake 命令来生成构建系统所需的文件: ```shell cmake . ``` 8. 使用生成的构建系统来编译构建库: ```shell make ``` 在构建过程完成后,你将在指定的目录(例如 `lib`)中找到生成的动态库静态库文件。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值