我有一个源文件,它为一个非常大的类定义了移动构造函数。我在 Linux 系统上用 g++ 4.9.2 编译它。当我转储生成的 ELF 对象文件的符号表时,我看到 2 个移动构造函数的列表。两个列表具有相同的地址、相同的大小、相同的类型,并且链接器链接得很好,没有 ODR 违规。当我反汇编目标文件时,我只看到一个移动构造函数。我的结论是符号表有两个指向同一位置的条目。
同样的行为也会发生在这个特定类的构造函数中,该类是在同一个源文件中定义的。
我看到的唯一一个我不完全理解的编译标志是“-m64”,但我不知道这将如何影响符号表。
我也用 g++ 9.2.0 尝试过,现在符号表中有 3 个条目!其中两个指向同一个地址,第三个指向地址0x0,位于.text.unlikely部分,并被标记为[clone .cold]。
为什么是这样?
编辑:实际上,我可以在家里用一个很小的班级重现这个。
// class.h
class VeryLargeClass
{
int data;
public:
VeryLargeClass(VeryLargeClass&&);
};
// class.cpp
#include "class.h"
VeryLargeClass::VeryLargeClass(VeryLargeClass&& other)
{
data = other.data;
other.data = 0;
}
Run Code Online (Sandbox Code Playgroud)
如果我用 编译它g++ -c -O3 class.cpp -o class.o,然后用 转储符号表,objdump -t class.o | c++filt我会得到以下内容: class.o: file format elf64-x86-64
SYMBOL TABLE:
0000000000000000 l df *ABS* 0000000000000000 main.cc
0000000000000000 l d .text …Run Code Online (Sandbox Code Playgroud)