- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
是否是 .eh_frame ELF 部分的缺失或损坏导致我的 C++ 代码中的异常停止工作?之前成功捕获的任何异常现在调用 std::terminate()。
我的情况:
我的 zzz.so 共享库有 try-catch block :
try {
throw Exc();
} catch (const Exc &e) {
LOG("ok " << e.what());
} catch (...) {
LOG("all");
}
加载 zzz.so 的可执行文件(使用 ldopen)。它调用了 zzz.so 中的一个函数
这怎么可能?
更新
我不知道这怎么可能,但是 Clang 3.3(FreeBSD clang 版本 3.3 (tags/RELEASE_33/final 183502) 20130610)解决了这个问题。
最佳答案
How is that possible?
当抛出异常时,控制传递给 __cxa_throw
例程(通常在 libstdc++.so
中),然后由该例程负责查找 catch
子句并在此过程中调用析构函数,或如果未找到 catch
则调用 std::terminate
。
那么答案很可能是第一个可执行文件(异常起作用的那个)使用能够解码库中的 .eh_frame
的 libstdc++.so
,而第二个应用程序(异常不起作用的应用程序),或者使用较旧(不兼容)的 libstdc++.so
版本,或者针对 libstdc++.a
的链接,或者其他一些东西这些行。
注意:引发异常的实际工作是由 libgcc_s.so.1
中的 _Unwind_RaiseException
完成的,因此即使两个应用程序都使用同样的libstdc++.so
,他们可能还是使用了不同的libgcc
。
更新:
Will I benefit from static linking libstdc++ and libgcc into my .so library?
也许吧。 TL;DR:这很复杂。
有几点需要考虑:
在除 i386 以外的任何平台上,您必须使用 -fPIC< 构建您自己的
,然后才能将它们链接到您的 libstdc++.a
和 libgcc.a
拷贝zzz.so
。通常这些库是在没有 -fPIC
的情况下构建的,并且不能静态链接到任何 .so
。
将 libstdc++.a
静态链接到您的 zzz.so
可能使其成为派生作品,并受 GPL (请咨询您的律师)。
即使从 zzz.so
导出了一个 _Unwind_RaiseException
,通常也已经有另一个 _Unwind_RaiseException
实例定义(较早加载)libgcc_s.so
,并且较早的实例将被调用,从而使您的解决方法无效。为确保 您的 _Unwind_RaiseException
拷贝被调用,您需要将 zzz.so
与 -Bsymbolic
链接起来,或使用特殊的链接器脚本在内部对 _Unwind_RaiseException
(以及 libgcc.a
中的所有其他内容)进行所有调用。
您的变通方法可能会解决 zzz.so
的问题,但可能会导致不相关的 yyy.so
出现问题,它加载得更晚,并且需要系统提供的 _Unwind_RaiseException
,而不是来自 zzz.so
的异常。这是隐藏所有 libgcc.a
符号并将它们置于 zzz.so
内部的另一个参数。
所以简短的回答是:这种变通办法可能会给您带来很多痛苦。
关于C++ 异常和 .eh_frame ELF 部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33035051/
我们正在为大学编写一个模拟器项目,我们必须使用 ELF 文件作为输入,但我们不太确定 ELF 文件是什么样的。它应该包含我们可以执行的某些操作(所有这些都应该用二进制表示),但它是否包含其他内容?还是
我目前正在研究 ELF 格式。我想确认一下我认为正确的事情。 ELF是一种格式,它代表可执行和可链接格式。在linux中,一切都是ELF格式。 当使用gcc编译带有-c和-fPIC文件的代码时,它会将
基本上,我希望能够在 elf 二进制文件的 debug dwarf 部分中更改源文件的路径。 最佳答案 Basically I want to be able to change the path t
我想编写一个实用程序来从 ELF 二进制文件中删除程序头。例如,当我运行 readelf -l/my/elf 时,我会得到所有程序头的列表:PHDR INTERP ... GNU_STACK GNU_
考虑使用 GCC 编译的 C 标准 hello world 程序,没有任何开关。如 readelf -s说,它包含 64 个符号。它还说.symtab部分是 1024 字节长。然而,每个符号表条目有
我正在尝试为 ARM 平台编写 elf 可执行加载程序。我在这里有一些查询 1) 如何生成可重定位或位置无关的 ELF 可执行文件(编译器和链接器选项是什么) 2) 如何加载上面生成的 ELF 可执行
假设我有一个 lib xxx.so。所以我得到了所有的函数名和参数 以下命令: readelf -Ws xxx.so |c++filt 它将输出以下内容: 711: 00270209 40
我正在创建一个 ELF 可执行文件,我需要知道操作系统需要哪些部分才能加载和执行它。 Details: OS: Ubuntu 10.04 (64-bit)Kernel ve
SHT_NULL的目的是什么? ELF 中的部分? 它是由操作系统还是加载程序引用的? 这个部分的大小是多少? 它与 NULL 指针有什么关系吗? 此外,为什么此部分在部分段映射中没有条目? 来自 E
我正在学习 ELF 并且有一段时间的疑问。我试图寻找答案,但徒劳无功。如果有人能给我答案或引导我到地方寻找答案,我会很感激。 我读到的几乎所有关于 ELF 的文档都说 .text 部分包含可执行的二进
问题场景 : 简单来说,我们是否有一个 Trace32 命令来从加载到目标的 ELF 文件中读取符号(及其内容)?我们有这种特殊情况,其中 ELF 文件的应用程序特定调试符号作为 ELF 中“.nol
我试图从 Linux 程序的 elf 文件中提取特定的字符串变量(即符号),甚至从它来自的 .o 中提取。 它在 .rodata 部分,显然我知道符号名称。 是否有一系列 objdump 样式的命令和
在 Linux 上,我试图将静态链接的 ELF 文件剥离为基本要素。当我运行时: strip --strip-unneeded foo 或者 strip --strip-all foo 生成的文件仍然
我有一个 STM32,我将 ELF 文件加载到 RAM 中(使用 OpenOCD 和 JTAG)。到目前为止,我还没有真正关注我加载的 ELF 文件的大小。 通常,当我编译一个对我的板来说太大的 EL
我有一个 STM32,我将 ELF 文件加载到 RAM 中(使用 OpenOCD 和 JTAG)。到目前为止,我还没有真正关注我加载的 ELF 文件的大小。 通常,当我编译一个对我的板来说太大的 EL
我需要学习手动创建 ELF 可执行文件。到目前为止,我一直在使用在线指南,例如: Manually Creating an ELF Executable ELF reference 几次失败后,我将我
我在 readelf 实用程序的帮助下打开了我的对象 Sprite 文件: readelf -a ./my_object.o |较少的 结果我得到了很多有趣的信息。 我在部分表中看到了一个带有“GRO
ELF 文件包含两个结构来处理重定位: Elf64_Rel: typedef struct { Elf64_Addr r_offset; Uint64_t r_info; }
我一直在阅读 ELF 规范,但无法弄清楚程序入口点和 _start 地址从何而来。 看起来他们应该在一个非常一致的地方,但我做了一些琐碎的程序,_start 总是在不同的地方。 谁能澄清一下? 最佳答
这是我的测试。我有一个由源 main.c 和 misc.c 组成的 main 应用程序和一个由 lib.cname); m++; } return 0; } misc.
我是一名优秀的程序员,十分优秀!