给已有的.so库重新封装一个新的库,并能使用新旧库中的函数

要求如题,这里给出一个简单的例子,自己亲测可用之后才记录下来。

假设有一个名为 libold.so 的现有库,它包含函数 old_function(),而我们需要在它的基础上重新封装一个新的库 libnew.so。此外,这个库除了提供旧库中的函数 old_function() 外,还提供一个新库中的函数 new_function()

步骤 1:编写封装代码,即新库的生成代码

先创建一个名为 NewDemo.cpp 的文件为例,内容如下,

cpp 复制代码
#include "old_lib.h"  // 假设这是 libold.so 的头文件

// 封装旧函数
void old_function_wrapper() {
    old_function();
}

// 新函数
void new_function() {
    // 实现新函数的逻辑
}

步骤 2:编译封装代码

bash 复制代码
$ gcc -c -fPIC wrapper.c -o wrapper.o

这里如果包含了多个库的头文件,以及想了解参数含义的,可看看这篇

这里给个例子,gcc / g++主要看你的文件类型:

bash 复制代码
$ gcc -I ../3rdparty/toolkit/ -I ../3rdparty/dart-sdk/include/ -c A.cpp -fPIC -o A.o

步骤 3:链接到现有库并创建新的动态库

bash 复制代码
$ gcc -shared -o libnew.so wrapper.o -L/path/to/old_lib -lold

这一步很关键,至少我的问题主要出在这步,也是我太菜,好久才捋顺思路,到最后没出问题。

  • -fPIC:生成位置无关代码,主要用在动态库中。
  • -L/path/to/old_lib:指定包含 libold.so 的目录,这个路径可以是相对路径也可以是绝对路径,到对应存放旧库的文件夹就可。
  • -lold:链接到 libold.so,这里的old是不包括库文件的不包括前缀(libxxx.so)和后缀(libxxx.so)的名字。

此时,libnew.so 就是一个新的动态库,我们可以直接使用 libnew.so 来访问新旧库中的函数,而无需直接与 libold.so 交互。
步骤 4:设置环境变量,确保新项目能找到旧的动态库

在指定项目的路径下,打开终端,设置环境变量:

bash 复制代码
$ export LD_LIBRARY_PATH=/path/to/old_lib:$LD_LIBRARY_PATH

此时,对通过命令对新的项目(这里假设是最简单的只包含新库的demo)进行编译生成可执行程序,命令如下:

bash 复制代码
$ g++ test.cpp -o test -lnew -L/new/so/path
相关推荐
无语子yyds9 小时前
C++双指针算法例题
数据结构·c++·算法
羑悻的小杀马特9 小时前
ProtoBuf语法揭秘:探秘编译魔法与性能优化策略,解锁多层级选项配置的底层奥秘
c++·编程·protobuf
fpcc9 小时前
C++编程实践——eventFD
linux·c++
仟濹9 小时前
「经典数字题」集合 | C/C++
c语言·开发语言·c++
Skrrapper9 小时前
【STL】set、multiset、unordered_set、unordered_multiset 的区别
c++·算法·哈希算法
冷崖9 小时前
QML-Model-View
javascript·c++
峥无9 小时前
《从适配器本质到面试题:一文掌握 C++ 栈、队列与优先级队列核心》
开发语言·c++·queue·stack
七夜zippoe9 小时前
仓颉FFI实战:C/C++互操作与性能优化
c语言·c++·性能优化
西哥写代码10 小时前
基于dcmtk的dicom工具 第十三章 dicom文件导出bmp、jpg、png、tiff、mp4
c++·mfc·dicom·dcmtk·tiffopen·dipngplugin·dijpegplugin
永远有缘11 小时前
Java、Python、C# 和 C++ 在函数定义语法上的主要区别
java·c++·python·c#