linux – 检测我的共享库的两个ABI不兼容版本加载到单个程序中

linux – 检测我的共享库的两个ABI不兼容版本加载到单个程序中,第1张

概述我写了一个包含几个不兼容版本的共享库.我改变了SONAME,所以他们被称为: > lib_mylib.so.1.0.0(旧库) > lib_mylib.so.2.0.0 mylib.so.1中只有一些函数,其他函数只在mylib.so.2中,很多函数都很常见(但有几个函数改变了参数的数量) 我担心可以将两个版本的mylib链接到单个应用程序中,例如当应用程序本身很大并且由许多库组成时.当部分重建应 我写了一个包含几个不兼容版本的共享库.我改变了SOname,所以他们被称为:

> lib_mylib.so.1.0.0(旧库)
> lib_mylib.so.2.0.0

mylib.so.1中只有一些函数,其他函数只在mylib.so.2中,很多函数都很常见(但有几个函数改变了参数的数量)

我担心可以将两个版本的mylib链接到单个应用程序中,例如当应用程序本身很大并且由许多库组成时.当部分重建应用程序时,可能会出现这种情况:

>申请
> app_lib1.so(使用mylib.so.1构建 – 我的lib的第一个版本)
> app_lib2.so(使用mylib.so.2重建 – 第二版)

我已经看到应用程序加载了两个版本(ldd报告两者).

那么,是否可以向mylib.so.2添加一些检查代码,以检测是否已经加载了两个版本的库,并且它们具有冲突的ABI /接口. (我无法修改lib_mylib.so.1来添加内容)

解决方法 您可以修改版本2库以在init期间解析某些特定于版本1的符号(dlsym(3))并在找到时崩溃.

例:

extern __attribute__((constructor)) voID _version_check2(){    if (dlsym(RTLD_DEFAulT,"version_1_function"))        abort();}

更优雅的解决方案是让版本2库模仿版本1的行为,但这会引入遗留代码.

编辑

为了将来证明,您还可以引入静态版本变量,所有函数调用将检查它是否与当前匹配.然后在将来的版本中,您只需要更改该变量的值,如果不匹配则崩溃.

编辑2

您还可以在每个版本2函数上调用此函数,以便迟早版本1加载时您的应用程序崩溃.

总结

以上是内存溢出为你收集整理的linux – 检测我的共享库的两个ABI不兼容版本加载到单个程序中全部内容,希望文章能够帮你解决linux – 检测我的共享库的两个ABI不兼容版本加载到单个程序中所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/yw/1030790.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-23
下一篇 2022-05-23

发表评论

登录后才能评论

评论列表(0条)

保存