gpt4 book ai didi

c++ - 在 Mac OS X 上的共享库中隐藏符号

转载 作者:可可西里 更新时间:2023-11-01 16:39:35 28 4
gpt4 key购买 nike

我们一直在构建一个大型开源 software在各种平台(Linux、Windows、Mac OS X、32 位和 64 位)上运行数年都没有问题。然而最近,Mac OS X 版本(64 位)停止正常工作并开始随机崩溃。它或多或少与我们构建机器上的 Mac OS X 从 10.7 更新到 10.8.2 相吻合(但编译器工具链没有改变,它仍然是 llvm-gcc 4.2.1)。

我们的应用程序由几个动态(共享)库和许多使用它们的可执行文件组成。共享库之一覆盖了 newdelete运营商出于各种原因。在 Mac OS X(和 Linux)上,默认导出所有符号,包括我们重载的 newdelete运营商。 Mac OS X 上的崩溃似乎与一些内存分配了一个内存子系统(不是我们的)然后通过我们自己的(和不兼容的)释放了 delete实现。

最明智的解决方案似乎是防止重载运算符对共享库的用户可见。这可以通过两种方式完成:用 __attribute__((visibility("hidden"))) 标记运算符。 ,或使用 -unexported_symbols_list链接器命令行选项,以防止某些符号被导出。不幸的是,第一个解决方案不起作用:gcc 发出警告说运算符的声明不同(在 <new> 中),因此属性将被忽略。从我在不同地方的阅读来看,第二种解决方案似乎是解决这个问题的正确方法。但是由于某些原因我们无法让它工作

链接共享库时,我们传递了 -Wl,-unexported_symbols_list unexported_symbols_list.txt g++ 的选项,它又应该传递给 ld。 unexported_symbols_list.txt文件包含以下符号列表:

__ZdaPv
__ZdaPvRKSt9nothrow_t
__ZdlPv
__ZdlPvRKSt9nothrow_t
__ZdlPvS_
__Znam
__ZnamRKSt9nothrow_t
__Znwm
__ZnwmPv
__ZnwmRKSt9nothrow_t

这些都是 new 的变体和 delete我们覆盖并希望隐藏。我们通过执行 nm libappleseed.dylib 找到了这些符号然后使用 c++filt 解开符号名称.

这是 CMake 生成的用于链接 libappeseed.dylib 的命令行:

/usr/bin/g++  -g -Werror -dynamiclib -Wl,-headerpad_max_install_names -framework Cocoa -lcurl    -Werror -Wl,-unexported_symbols_list -Wl,unexported_symbols_list.txt -o ../mac-gcc4/appleseed/libappleseed.dylib [...]

不幸的是,尽管我们做出了所有努力,但符号似乎仍然存在(如 nm 所示)。

知道我们做错了什么吗?我们可以尝试另一种方法吗?


2012 年 12 月 19 日更新:

我们的问题和假定的解决方案在 Apple 的这份技术说明中得到了很好的涵盖:http://developer.apple.com/library/mac/#technotes/tn2185/_index.html (“覆盖新建/删除”部分)。

指向相关源代码的指针:

nm 的片段使用 -fvisibility=hidden 构建 libappleseed.dylib 后的输出正在运行 strip -x libappleseed.dylib :

...
00000000002a41b0 T __ZdaPv
00000000002a41f0 T __ZdaPvRKSt9nothrow_t
00000000002a4190 T __ZdlPv
00000000002a41d0 T __ZdlPvRKSt9nothrow_t
00000000002a4060 T __Znam
00000000002a4130 T __ZnamRKSt9nothrow_t
00000000002a3ff0 T __Znwm
00000000002a40d0 T __ZnwmRKSt9nothrow_t
...

最佳答案

您应该使用 -fvisibility=hidden 进行构建,然后仅导出您想要的内容。在这里阅读:

http://gcc.gnu.org/wiki/Visibility

它还解释了 -fvisibility-inlines-hidden。许多大型库(例如 Qt)都使用它。好处是相当可观的。

关于c++ - 在 Mac OS X 上的共享库中隐藏符号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13793325/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com