有一次在编译adb的时候,遇到了以下问题:
out/target/product/xxx/obj/STATIC_LIBRARIES/libxxx_intermediates/libxxx.a(xxx.o): In function `getxxx':
/home/wuhx/e500/xxx/android/xxx/external/libxxx/xxx.c:82: undefined reference to `systoolxxx'
clang: error: linker command failed with exit code 1 (use -v to see invocation)
build/core/executable_internal.mk:75: recipe for target 'out/target/product/xxx/obj/EXECUTABLES/adbd_intermediates/LINKED/adbd' failed
make: *** [out/target/product/xxx/obj/EXECUTABLES/adbd_intermediates/LINKED/adbd] Error 1
一看是undefined reference to 'systoolxxx'
错误,立马到/home/wuhx/e500/xxx/android/xxx/external/libxxx/
目录下打开xxx.c
文件,查看有没有声明了这个函数,发现里面是有声明了extern int systoolxxx()
这个函数的。这个systoolxxx
函数存在于另外一个静态库(暂且叫他为libxxx2
)。接着查看当前目录(libxxx目录)下的Android.mk
文件,里面已经引用了相应的libxxx2
静态库。在该目录下执行mm
命令,编译通过。回到adb目录,执行mm
命令,同样的问题仍然出现。
在adb里的某个文件中,我引用了/home/wuhx/e500/xxx/android/xxx/external/libxxx/xxx.c
中的一个函数getxxx
,而该函数引用了另外一个静态库(libxxx2)里面的一个函数systoolxxx
。而在adb的Android.mk文件里面,我都引用了这个两个静态库libxxx和libxxx2。值得注意的是,libxxx也引用了libxxx2。adb的Android.mk文件部分如下:
LOCAL_STATIC_LIBRARIES := \
...
libxxx2 \
libxxx \
我明明已经在adb的mk文件中的LOCAL_STATIC_LIBRARIES
引用了这两个静态库libxxx
和libxxx2
,为什么还会抛出undefined reference to 'systoolxxx'
这种问题呢?
然后,我想会不会跟LOCAL_STATIC_LIBRARIES
引用静态库的先后顺序有关呢?接着,我把这两个静态库的引用位置调转了一下,变成以下的顺序:
LOCAL_STATIC_LIBRARIES := \
...
libxxx \
libxxx2 \
保存,编译,make completed successfully!
总结:
当LOCAL_STATIC_LIBRARIES
引用了两个有调用关系的静态库的时候,需要把其中被调用的库放在调用者的后面。