[前提]
最近在写新系统代码的时候, 因为引用了一个包含了如下内容的头文件, 导致系统core的莫名奇妙, core在了打log的时候, std::string的析构上, 代码如下:
... ...
#pragma pack(1)
strcut XXX {
... ...
}
#pragma
所有包含了这一头文件的cpp中的类, 打log即挂(后面实验, 要core可以很多种办法).
后来发现是因为我编译加了 -O2, 不加的话不会挂.
这里请注意, #pragma pack(1)并没有以#pragma pack()结束.
[原因分析]
GDB检查了一下core的原因, 是因为std::string在#pragma后面, 而上面那个写法比较坑, 并没有以#pragma pack()结束, 导致后面的string全部都按1字节对齐, 会导致一些计算长度上的误差, 在-O2编译的时候, 会出现一系列的 malloc/free 错误.
这里贴上core信息:
0x00000000006224c9 in __gnu_cxx::__exchange_and_ad