Android NDK:获取java.lang.UnsatisfiedLinkError:dlopen失败:找不到“libffmpeg.so”引用的符号“signal”

我有一个video微调应用程序代码。

它的Android.mk文件代码如下所示:

MY_LOCAL_PATH := $(call my-dir) 

包括$(all-subdir-makefiles)

 LOCAL_PATH :=$(MY_LOCAL_PATH) include $(CLEAR_VARS) LOCAL_MODULE := video-trimmer LOCAL_SRC_FILES := video-trimmer.c LOCAL_C_INCLUDES := $(MY_LOCAL_PATH) $(MY_LOCAL_PATH)/ffmpeg LOCAL_SHARED_LIBRARIES := ffmpeg LOCAL_LDLIBS += -lz -llog include $(BUILD_SHARED_LIBRARY) 

和Application.mk文件的代码是:

 APP_MODULES := ffmpeg video-trimmer APP_OPTIM := debug 

当我尝试运行此应用程序时,出现以下错误:

 02-26 16:06:05.779: E/AndroidRuntime(4092): FATAL EXCEPTION: main 02-26 16:06:05.779: E/AndroidRuntime(4092): Process: net.video.trimmer, PID: 4092 02-26 16:06:05.779: E/AndroidRuntime(4092): java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "signal" referenced by "libffmpeg.so"... 02-26 16:06:05.779: E/AndroidRuntime(4092): at java.lang.Runtime.loadLibrary(Runtime.java:364) 02-26 16:06:05.779: E/AndroidRuntime(4092): at java.lang.System.loadLibrary(System.java:526) 02-26 16:06:05.779: E/AndroidRuntime(4092): at net.video.trimmer.service.VideoTrimmingService.onCreate(VideoTrimmingService.java:29) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.app.ActivityThread.handleCreateService(ActivityThread.java:2585) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.app.ActivityThread.access$1800(ActivityThread.java:139) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1292) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.os.Handler.dispatchMessage(Handler.java:102) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.os.Looper.loop(Looper.java:136) 02-26 16:06:05.779: E/AndroidRuntime(4092): at android.app.ActivityThread.main(ActivityThread.java:5086) 02-26 16:06:05.779: E/AndroidRuntime(4092): at java.lang.reflect.Method.invokeNative(Native Method) 02-26 16:06:05.779: E/AndroidRuntime(4092): at java.lang.reflect.Method.invoke(Method.java:515) 02-26 16:06:05.779: E/AndroidRuntime(4092): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 02-26 16:06:05.779: E/AndroidRuntime(4092): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 02-26 16:06:05.779: E/AndroidRuntime(4092): at dalvik.system.NativeStart.main(Native Method) 

我的video-trimmer.so和ffmpeg.so是在\libs\armeabi中生成的。

提前致谢。

Solutions Collecting From Web of "Android NDK:获取java.lang.UnsatisfiedLinkError:dlopen失败:找不到“libffmpeg.so”引用的符号“signal”"

signal是一个内联函数,直到平台android-21,现在它不是内联了。

当你使用ndk r10时,默认情况下使用的是android-21,但是它并不完全兼容运行以前的Android版本的设备。 在你的情况下,信号不能在你的设备上find(但它可以在棒棒糖上正常运行)。

当使用NDK时,您应该使用对应于您的android:minSdkVersion的平台( APP_PLATFORM:=android-XX )。

所以在这里你可以在Application.mk Makefile中设置APP_PLATFORM:=android-15 ,你的lib将使用信号的内联版本,所以它不会在运行时查找它的符号。