覆盖静态库中的弱符号
我想从多个来源为我的项目创建一个静态.a库,其中一些定义弱函数,另一些实现它们。 比方说我有:
lib1.c:
void defaultHandler() { for(;;); } void myHandler() __attribute__((weak, alias ("defaultHandler")));
lib2.c:
void myHandler() { /* do my stuff here */ }
然后我想把它们放到一个单独的库中,这样它对于最终应用程序来说似乎是透明的
$ ar -r libhandlers.a lib1.o lib2.o
但是在myHandler
中现在有2个符号myHandler:
$ nm libhandlers.a | grep "myHandler" 00000001 W myHandler 00000581 T myHandler
然后在使用lib时,弱引用被链接。 我目前唯一的解决方案是不包含在库lib2.c
而是将其作为源添加到应用程序的Makefile中…这是不满意的,因为我只想提供几个库而不是一大堆文件。
--whole-archive
选项也不令人满意,因为我在嵌入式系统上工作,我不想包含所有我不需要的东西。
有没有办法编译库,以便弱符号消失,如果提供强大的符号?
注意:我使用的是arm-none-eabi-gcc v4.8
这是.a
库工作方式的副产品 – 它们只是.o
文件的集合。
在编译链接时发生的事情是对名称的第一次引用被解析为弱引用,并且强名称永远不会被查看。
您可以通过实际制作相同的名称和强大来自己测试,并且您将看到完全相同的行为。
如果您希望首先解析强引用,然后将它们放在存档中,或者在链接行中创建一个单独的强存档和链接。
虽然不能直接应用于您的情况,但由于您使用的是嵌入式环境,因此在创建/使用.so
动态库而不是.a
存档时,弱引用和强引用会正确生效。 当您创建.so时,构成库的所有弱引用都不会生成错误,并且只有其中一个将用于最终产品; 如果在任何地方都有一个强大的定义,那么它就会被使用而不是任何弱的(这只有在你创建一个.so
,你链接所有单独组成的.o
文件,或者使用它们时才能正常工作)创建.so
时的--whole-archive
,如果链接到.a
)。