Android NDK: Получение java.lang.UnsatisfiedLinkError: dlopen failed: невозможно найти символ "сигнал", на который ссылается "libffmpeg.so",

У меня есть код приложения триммера видео.

Код файла 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)

Мои видео-trimmer.so и ffmpeg.so создаются в \libs\armeabi.

Спасибо заранее.

Ответ 1

signal была встроенной функцией до платформы android-21, теперь она больше не встроена.

Когда вы используете ndk r10, по умолчанию используется android-21, но он не полностью ретро-совместим с устройствами, использующими прежние версии Android. В вашем случае сигнал не может быть найден на вашем устройстве (но он будет работать правильно на Lollipop).

При использовании NDK вы должны использовать платформу (APP_PLATFORM:=android-XX), которая соответствует вашему android:minSdkVersion.

Итак, здесь вы можете установить APP_PLATFORM:=android-15 внутри Application.mk Makefile, и ваш lib будет использовать встроенную версию сигнала, поэтому он не будет искать свой символ во время выполнения.