gpt4 book ai didi

Android NDK : Getting java. lang.UnsatisfiedLinkError: dlopen failed: 找不到 "signal"引用的符号 "libffmpeg.so"

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:01:15 37 4
gpt4 key购买 nike

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

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

提前致谢。

最佳答案

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

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

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

所以这里可以在Application.mk Makefile里面设置APP_PLATFORM:=android-15,你的lib会使用inline版本的signal,所以看起来不会运行时的符号。

关于Android NDK : Getting java. lang.UnsatisfiedLinkError: dlopen failed: 找不到 "signal"引用的符号 "libffmpeg.so",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28740315/

37 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com