g++生成空的对象文件

g++ produces empty object file

本文关键字:对象 文件 g++      更新时间:2023-10-16

我正试图将一个基本的数组包装器模板类编译到.o文件中,以尝试并弄清楚如何创建动态库。但是,当使用编译源代码时

g++ -std=c++0x -c array.cpp

生成的文件只有大约650个字节。我用nm检查了这个文件,发现它包含的唯一符号是

00000001 r _ZStL13allocator_arg
00000000 r _ZStL19piecewise_construct

这似乎是C++11编译的特点,因为当在没有-std=C++0x标志的情况下编译时,它们就消失了。

试图用命令编译程序测试代码

g++ -std=c++0x -o tester tester.cpp array.cpp

为array.cpp中的所有内容生成链接器错误,但在其他方面编译干净。

老实说,我不知道这是怎么回事。如果您怀疑这是我的代码本身的问题,而不是我如何编译它的问题,我可以发布array.cpp和array.hpp的内容。

这很正常。模板只有在实例化时才会产生代码,而您还没有做到这一点。您只提供了模板。当编译器编译模板时,它没有理由生成任何特定的模板实例,并为模板参数填充实际类型。

稍后,编译器编译其他源文件,在这些文件中使用模板类型。这也不会导致实例化。它只是告诉编译器它应该期望在其他地方找到模板的实例。编译器在对象文件中注意到了这一点。然后,链接器查找编译器说应该找到的定义,但它失败了。

这就是为什么我们总是建议您在页眉中为模板提供与声明内联的定义。这样,当编译器看到你使用模板时,它可以立即实例化模板,使用它在头中看到的定义。如果您在多个源文件中使用模板,您可能会在多次实例化模板时得到多个定义,但这是允许的,并且链接器知道如何处理它。

另一种选择是显式实例化array.cpp文件中的模板,但只内联定义模板成员更容易。

如果array.cpp只包含模板,则不单独编译,可能会将其称为array.hpp.