Android NDK:获取java.lang.UnsatisfiedLinkError:dlopen失败:找不到符号";“信号”;引用为;libffmpeg.so“;

Android NDK:获取java.lang.UnsatisfiedLinkError:dlopen失败:找不到符号";“信号”;引用为;libffmpeg.so“;,android,android-ndk,ffmpeg,Android,Android Ndk,Ffmpeg,我有一个视频剪辑应用程序代码 其Android.mk文件代码如下: MY_LOCAL_PATH := $(call my-dir) 包含$(所有子磁盘生成文件) Application.mk文件代码为: APP_MODULES := ffmpeg video-trimmer APP_OPTIM := debug 尝试运行此应用程序时,出现以下错误: 02-26 16:06:05.779: E/AndroidRuntime(4092): FATAL EXCEPTION: main 0

我有一个视频剪辑应用程序代码

其Android.mk文件代码如下:

MY_LOCAL_PATH := $(call my-dir)
包含$(所有子磁盘生成文件)

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)
My video-trimmer.so和ffmpeg.so在
\libs\armeabi
中生成


提前感谢。

信号在android-21平台之前是内联函数,现在不再是内联函数

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

使用NDK时,您应该使用与您的
android:minSdkVersion
相对应的平台(
APP\u platform:=android XX


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

此链接将帮助您:-@japanjotsingh谢谢。感谢您的快速响应。如果您尝试在应用程序内设置
APP\u PLATFORM:=android-15
。mk?@ph0b谢谢您的回复。我下载了Uday Rayala的()视频剪辑器并重新编译了它,重新编译后我发现我的libffmpeg.so文件是7.x mb,而Uday的libffmpeg文件是5.x mb更改应用程序平台并没有解决您的问题?文件大小的差异并不意味着什么。从现在开始,NDK和平台的行为与Uday的项目编译时有很多不同。我现在正在尝试创建一个水印应用程序。我使用了来自网站ffmpeg.org的命令。但当尝试执行时,我在logcat中得到一个错误:无法识别的选项过滤器\u complex。我的stackoverflow问题是-Android Studio编译不需要Android.mk,使用Android.ndk gradle。如何设置“应用程序平台”?目前还没有明确的方法。您可以修改CompileSDK版本以更改APP_平台版本。我在这里报告了这个问题:
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)