调用jni共享库错误分析

来源:互联网 发布:涉水险有必要买吗 知乎 编辑:程序博客网 时间:2024/06/01 09:46

启动APK的时候报错:

E/AndroidRuntime(23709): java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "_ZN14SkImageDecoder7FactoryEP8SkStream" referenced by "libjni_fireair.so"...


在jni的源码中找不到符号


readelf -s libjni_fireair.so 

查看没有找到对应的,

考虑到是交叉编译,改用 arm-none-linux-gnueabi-objdump -d libjni_fireair.so 命令

还是找不到符号_ZN14SkImageDecoder7FactoryEP8SkStream , 说明是调用了第三方的库造成找不到符号。


源码中搜索SkImageDecoder

发现SkImageDecoder* bounddecoder = SkImageDecoder::Factory(&stream);

有这样一个调用


搜索头文件SkImageDecoder.h

找到路径 external/skia/include/core/SkImageDecoder.h



jni_fireair下的Android.mk 

里面有一句 LOCAL_SHARED_LIBRARIES := libskia


原来调用了共享库skia, 不过由于不同平台该库不一样,造成找不到符号。


0 0