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

Posted

技术标签:

【中文标题】Android NDK:获取 java.lang.UnsatisfiedLinkError:dlopen 失败:找不到“libffmpeg.so”引用的符号“signal”【英文标题】:Android NDK : Getting java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "signal" referenced by "libffmpeg.so" 【发布时间】:2015-04-28 16:53:34 【问题描述】:

我有一个视频修剪器应用程序代码。

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 中生成的。

提前致谢。

【问题讨论】:

这个链接会帮助你:- ***.com/questions/18111739/… @japanjotsingh 谢谢。感谢您的快速回复 您可以尝试在您的 Application.mk 中设置APP_PLATFORM:=android-15 吗? @ph0b 感谢您的回复。我下载了 Uday Rayala (github.com/uday-rayala/video-trimmer) 的视频修剪器并重新编译它,重新编译后我发现我的 libffmpeg.so 文件是 7.x mb,而 Uday 的 libffmpeg 有 5.x mb 更改 APP_PLATFORM 没有解决您的问题?文件大小差异并不意味着很多。从现在到编译 Uday 的项目时,NDK 和平台的行为有很多不同。 【参考方案1】:

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

当您使用 ndk r10 时,默认使用 android-21,但它与运行旧 Android 版本的设备不完全兼容。在您的情况下,您的设备上找不到信号(但它会在 Lollipop 上正常运行)。

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

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

【讨论】:

我现在正在尝试创建一个水印应用程序。我使用了网站 ffmpeg.org 的命令。但是当试图执行时,我在 logcat 中得到一个错误: Unrecognized option filter_complex 。我的 *** 问题是 - ***.com/questions/28763388/… Android Studio 编译不需要Android.mk,使用android.ndk gradle。如何设置“APP_PLATFORM”? 目前还没有干净的方法来做到这一点。您可以修改 compileSdkVersion 以更改 APP_PLATFORM 版本。我在这里报告了这个问题:code.google.com/p/android/issues/detail?id=177530

以上是关于Android NDK:获取 java.lang.UnsatisfiedLinkError:dlopen 失败:找不到“libffmpeg.so”引用的符号“signal”的主要内容,如果未能解决你的问题,请参考以下文章

Android NDK- JNI 异常

Android NDK- JNI 异常

导入 Android NDK 项目(解码 OGG)

如何设置 Cordova Android 项目以使用 NDK

JNI- java.lang.UnsatisfiedLinkError:找不到本机方法

使用 Android Studio (1.3 RC) 找不到 ARM64 NDK 本机库