web-dev-qa-db-ja.com

Android NDK:Java.lang.UnsatisfiedLinkErrorの取得:dlopenが失敗しました:「libffmpeg.so」によって参照されるシンボル「signal」が見つかりません

ビデオトリマーアプリケーションコードがあります。

その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で生成されます。

前もって感謝します。

10

signalは、プラットフォームAndroid-21まではインライン関数でしたが、現在はインラインではありません。

Ndk r10を使用する場合、デフォルトでAndroid-21が使用されますが、以前のAndroidバージョンを実行しているデバイスとの完全な下位互換性はありません。この場合、デバイスで信号が見つかりません(ただし、Lollipopでは正しく実行されます)。

NDKを使用する場合は、APP_PLATFORM:=Android-XXに対応するプラットフォーム(Android:minSdkVersion)を使用する必要があります。

したがって、ここではAPP_PLATFORM:=Android-15Application.mk Makefile内に設定できます。ライブラリはインラインバージョンのシグナルを使用するため、実行時にそのシンボルを検索しません。

14
ph0b