2016-10-11 62 views
2

我是NDK开发的新手。我已经使用NDK生成xxx.so文件,它可以在Android 5.0或更高版本上正常工作,但它会在Android 4.4或更高版本上崩溃。java.lang.UnsatisfiedLinkError:dlopen失败:找不到“xx.so”引用的符号“srand”

日志是:

java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "srand" referenced by "xx.so"... at java.lang.Runtime.loadLibrary(Runtime.java:362) at java.lang.System.loadLibrary(System.java:525) at com.uniquestudio.lowpoly.LowPoly.(LowPoly.java:14) at com.uniquestudio.lowpolyandroid.MainActivity.onCreate(MainActivity.java:22) at android.app.Activity.performCreate(Activity.java:5372) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2257) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2349) at android.app.ActivityThread.access$700(ActivityThread.java:159) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:137) at android.app.ActivityThread.main(ActivityThread.java:5419) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:525) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1187) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003) at dalvik.system.NativeStart.main(Native Method)

+0

可能重复[Can not load library:reloc \ _library \ [1285 \]:can not locate'rand'](http://stackoverflow.com/questions/27338318/cannot-load-library-reloc-library1285-cannot -locate-rand) –

+0

注意:与dup不同的符号,但是是相同的原因。 –

回答

1

正如丹在评论中指出了这一点,你的问题肯定是来自对编译一个Android API级> = 21。

要解决您的问题,您可以针对与您的APK minSdkVersion相同的平台编译您的代码。

你是如何使用NDK的?如果您使用NDK-建立,添加Application.mk文件旁边的Android.mk文件,与内容APP_PLATFORM:=android-14(其中14是你的minSdkVersion)。

相关问题