动态链接- c++名称混淆
dynamic linking - C++ name mangling in a so
我是这样做的:
我从
更改了一个。h文件SomeObj* getCacheObj( int i = 0 );
SomeObj* getCacheObj( int i );
SomeObj* getCacheObj();
我重新编译了代码(没有问题),更改了一些东西。so (多个 so文件中的一个)。然后我用这个替换了设备上的旧so,并在加载so时得到以下错误:undefined symbol: _ZN13KeypathHelper11getCacheObjEv
现在奇怪的是,我被告知这个类只在这个so文件中使用(我怎么能确定?)我没有那么多经验,也不知道该如何调查。欢迎提出任何建议。
这个特殊的问题是由于另一个so文件使用了KeypathHelper类,而我只替换了包含它的那个。我发现其他需要更新的方式是通过为KeypathHelper greping所有so。
_ZN13KeypathHelper11getCacheObjEv
符号是KeypathHelper::getCacheObj()
的混乱名称(例如,您可以轻松地使用c++filt
进行翻译)。考虑到你只添加了一个方法,而加载共享对象的任何东西都找不到,这让我认为你要么没有更新共享对象,要么忘记为KeypathHelper::getCacheObj()
提供定义(换句话说-实现方法)。
为了进行调查,您必须查看无法解析符号的原因。通常,开发人员对此有自己的感觉。例如,如果二进制XXX
由于未解析的符号而无法加载库YYY
,则XXX
正在使用它,并且它似乎不在YYY
中(或其他任何地方)。如果没有意义,可以求助于读取ld.so(8)手册页,并使用可用的方法调试动态链接器,如定义LD_DEBUG
。
另外,@PlasmaHH问了一个非常好的问题。如果您只对头文件进行了更改,那么您必须知道,单个函数/方法具有参数的默认值,这与两个函数/方法中一个有参数而另一个没有参数是不一样的。
至于你的第二个问题,关于如何确保共享对象中的符号不被外部使用——你必须改变符号的可见性,这样外部的任何人都无法链接/解析/使用该符号。例如,参见GCC可见性。
希望有帮助。好运!
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 从链接列表c++中删除一个项目
- 有根的二进制搜索树.保留与其父级的链接
- 读取文件的最后一行并输入到链接列表时出错
- 静态数据成员的问题-修复链接错误会导致编译器错误
- node-gyp 在 macOS 上未正确链接库
- 基于boost的程序的静态链接——zlib问题
- 无法链接 CMake 中的本地库
- 内联函数中具有内部链接的全局变量
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 使用gcc从静态链接的文件中查找可选符号
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 将--whole archive链接器选项与CMake和具有其他库依赖项的库一起使用
- 下面是我为检测链接列表中的循环而制作的代码
- 有了gcc,是否可以链接库,但前提是它存在
- 使用C链接在函数内部创建C++模板
- Visual Studio mkl_link_tool.exe链接错误
- 尝试链接我的着色器时,我收到错误代码"error c5145 must write to gl_position"
- 有人能帮我处理这个链接列表吗?C++