CLion中C++加载静态库和动态库

记录学习内容

编译环境:

IDE:CLion 2022.2

ToolChains:MinGW64

一、加载静态库 

1、生成静态库

用 求平方 举例:

先编写静态库文件Math.cpp 输出num的平方

#include <iostream>
#include <cstdlib>
using namespace std;

void customLibTest(const char * num) {
    double x = strtod(num, nullptr);
    double res = x * x;
    cout << "输入x: " << x << "的平方是" << res << endl;
}

在项目CMakeList.txt中用

add_library(Math STATIC math.cpp)

build生成静态库 工程目录下会有Math.lib创建出来

2、调用静态库

在调用静态库的项目目录下创建libs文件夹用来存放上一步生成的静态库文件Math.lib

在CmakeList.txt中进行如下配置:

cmake_minimum_required(VERSION 3.23)
project(Test1)

set(CMAKE_CXX_STANDARD 11)

link_directories(libs) #链接文件夹 指定引用的外部库文件夹路径 用在add_executable或add_library之前

add_executable(Test main.cpp main.h)

target_link_libraries(Test Math.lib) #链接目标库文件 指定引用的外部库文件 用在add_executable或add_library之后

 在main.cpp中如下图所示代码 进行调用:

#include <iostream>
//加载静态库
#pragma comment(lib, "Math.lib")
//声明静态库中的方法
void customLibTest(const char * num);

int main() {
    customLibTest("2");
    return 0;
}

结果:

二、加载动态库

1、生成动态库

这里生成动态库的环境是Windows,所以生成的应该是dll文件,如果是Linux生成的应该是so文件。但是调用方式都是一样的。

在CLion中新建动态库工程:

 还是以求平方为例 编写.cpp和.h如下:

library.h

#ifndef MATH_LIBRARY_H
#define MATH_LIBRARY_H

void customLibTest(const char * num);

#endif //MATH_LIBRARY_H

ps:如果有java jna与动态库dll交互的需求 需要在上面头文件的方法前加上 extern "C" (同时要注意的是java版本位数要与编译dll的环境一致,即32位就都是32位,64位就都是64位)

library.cpp

#include "library.h"

#include <iostream>
using namespace std;

void customLibTest(const char * num) {
    double x = strtod(num, nullptr);
    double res = x * x;
    cout << "输入x: " << x << "的平方是" << res << endl;
}

CMakeList.txt

cmake_minimum_required(VERSION 3.23)
project(Math)

set(LIBRARY_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/output) #修改所生成库的目标文件夹
set(CMAKE_CXX_STANDARD 11)

add_library(Math SHARED library.cpp)

build一下,会在工程目录下创建output文件夹,文件夹下就是生成出来的dll库文件。

2、调用动态库

先将上一步生成出来的文件都复制到引用动态库的Test1工程目录的libs下:

调用动态库的工程CMakeList.txt代码配置如下:

cmake_minimum_required(VERSION 3.23)
project(Test1)

set(CMAKE_CXX_STANDARD 11)

link_directories(libs) #链接文件夹 用在add_executable或add_library之前

add_executable(Test main.cpp main.h)

target_link_libraries(Test cygMath.dll libMath.dll.a) #链接目标库文件 用在add_executable或add_library之后

 C++代码main.cpp中调用的时候可以直接写:

#include <iostream>

//声明动态库的方法
void customLibTest(const char * num);

int main() {
    customLibTest("8");
    return 0;
}

运行结果:

### 如何在CLion中安装xlnt库 为了在CLion项目中成功集成并使用`xlnt`库,需遵循一系列配置步骤来确保环境设置正确。考虑到`xlnt`是一个基于C++开发用于操作Excel文档的第三方库[^2],下面提供一种常见的做法。 #### 安装依赖项 首先确认本地已安装必要的构建工具链以及Git版本控制系统。对于Linux用户来说,可能还需要额外安装一些编译器支持包如`build-essential`。 #### 获取源码 可以通过克隆官方GitHub仓库获取最新版`xlnt`源代码: ```bash git clone https://github.com/tfussell/xlnt.git cd xlnt ``` 如果希望应用特定修复,则可以从指定链接下载带有修正补丁的分支版本[^1]。 #### 构建静态或共享库 进入解压后的目录后执行如下命令完成编译过程(假设已经安装好cmake): ```bash mkdir build && cd build cmake .. make -j$(nproc) sudo make install ``` 上述指令会创建名为`libxlnt.a`的静态库文件,默认放置于系统的标准路径下以便后续链接调用;当然也可以调整参数生成动态链接库形式(`.so`)供其他程序加载使用。 #### 配置CLion工程 打开IDE之后新建或者导入现有CMakeLists.txt文本编辑,在其中加入对外部资源位置声明语句指向刚才安放好的头文件夹二进制产物所在处: ```cmake set(XLNT_INCLUDE_DIRS /usr/local/include/xlnt/) set(XLNT_LIBRARIES /usr/local/lib/libxlnt.a) add_executable(${PROJECT_NAME} main.cpp) target_include_directories(${PROJECT_NAME} PRIVATE ${XLNT_INCLUDE_DIRS}) target_link_libraries (${PROJECT_NAME} ${XLNT_LIBRARIES}) ``` 此时应该可以在编写测试案例验证是否能够正常引用到目标函数接口了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值