我正在编写C ++代码以在独立环境(基本上是ARM板)中运行。它一直很顺利,除了我遇到了一个绊脚石 - 全局静态构造函数。
据我所知,.ctors部分包含每个静态构造函数的地址列表,我的代码只需迭代这个列表并调用每个函数。但是,我发现我的二进制文件中的这一部分实际上是空的!谷歌指出使用“.init_array”代替“.ctors”(EABI的东西),但这并没有改变任何东西。
关于为什么我的静态构造函数不存在的任何想法?相关的链接描述文件和objdump输出如下:
.ctors :
{
. = ALIGN(4096);
start_ctors = .;
*(.init_array);
*(.ctors);
end_ctors = .;
}
.dtors :
{
. = ALIGN(4096);
start_dtors = .;
*(.fini_array);
*(.dtors);
end_dtors = .;
}
-
2 .ctors 00001000 8014c000 8014c000 00054000 2**2
CONTENTS, ALLOC, LOAD, DATA
<snip>
8014d000 g O .ctors 00000004 start_ctors
<snip>
8014d000 g O .ctors 00000004 end_ctors
我正在使用arm-elf目标GCC编译器(4.4.1)。
更新:输出二进制文件也带有__static_initialization_and_destruction_0
符号,这是我以前从未见过的。
更新2:这是对编译对象文件(链接到主二进制文件)的objdump的摘录,其中.ctors部分完整无缺:
21 .ctors 00000004 00000000 00000000 00000864 2**2
CONTENTS, ALLOC, LOAD, RELOC, DATA
RELOCATION RECORDS FOR [.ctors]:
OFFSET TYPE VALUE
00000000 R_ARM_ABS32 _GLOBAL__I__ZN9SomeStaticClass10m_InstanceE
答案 0 :(得分:1)
这最终成为构建系统问题 - 在链接器命令行上多次指定链接器脚本,这会导致g ++窒息。