我有一个用g ++编译的共享对象(.so)文件,在Windows中,大小约为2MB(.DLL,用Visual Studio 2008编译,/ O2),但在Linux中,如果使用g ++编译,其大小为10MB -O2 flag。
即使我用-Os标志编译它,最终的.so文件大小仍然有5MB。
我知道可执行文件可以通过strip命令减少,但它似乎无法使用.so文件(它可以被剥离,但无法加载)。
如何减少此共享对象的文件大小?是否有共享对象的strip命令?
EDIT1:
我的g ++版本是4.1.2。我在代码中使用了Boost 1.43。
我的makefile中的编译标志:
g++ -DNDEBUG -D_PYTHON -DBOOST_PYTHON_STATIC_LIB -I"boost_1_43_0" -I"/usr/local/include/python2.6" -fno-tree-vrp -Os -Wall -c -fmessage-length=0 -MMD -MP -MF"$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -o"$@" "$<"
链接标志:
LIBS := -lm -lz -ltidy -lpng14 -lxml2 -liconv -lboost_regex-gcc41-mt-s -lboost_serialization-gcc41-mt-s -lboost_python-gcc41-mt-s -lpython2.6
这是我的共享对象的ldd:
linux-gate.so.1 => (0x00327000)
libz.so.1 => /lib/libz.so.1 (0x004f4000)
libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x00110000)
libm.so.6 => /lib/libm.so.6 (0x00f31000)
libgcc_s.so.1 => /lib/libgcc_s.so.1 (0x0053b000)
libc.so.6 => /lib/libc.so.6 (0x00328000)
/lib/ld-linux.so.2 (0x0077d000)
我将尝试使用-fno-inline标志,但我想知道这会影响编译代码的性能。
我怀疑是因为我静态链接到python 2.6?在我的ldd中应该有libpython2.6.so,但是我没有看到它。
我的链接或编译标志有什么问题吗?
答案 0 :(得分:1)
看起来这些外部库是静态的,它们被合并到您的库中。我怀疑这是因为ldd没有显示到它们的链接,这是巨大可执行文件的常见原因。
g ++中的-static链接器选项可能会导致此问题,或者您链接的库只能作为静态库使用。