-fpic 与-fPIC的区别

2019-04-15 17:27发布

                                                    -fpic 与-fPIC的区别

前言

        在编译动态库的时候,我们应该需要使用-fpic 或-fPIC参数。如下所示:          然后,使用gcc或g++ 命令生成动态库

pic 与PIC的异同

        相同点:都是为了在动态库中生成位置无关的代码。通过全局偏移表(GOT)访问所有常量地址。程序启动时动态加载程序解析GOT条目。         不同点:如果链接的可执行文件的GOT大小超过计算机特定的最大大小,则会从链接器收到错误消息,指示-fpic不起作用;在这种情况下,请使用-fPIC重新编译。GOT大小根据操作系统的不同而大小不一样,SPARC上为8k,在AArch64上为28k,在m68k和RS / 6000上为32k。x86没有此限制。

总结

        为了兼容各个系统,在生成位置无关的代码的时候,应该使用-fPIC参数。

参考资料

       [1].https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#Code-Gen-Options