在Play商店上传后,NDK应用程序崩溃

时间:2013-04-30 11:53:01

标签: android android-ndk

我上传了一个应用程序到Playstore。该应用程序包含本机C代码。我使用NDK成功编译了它,创建了签名的apk。我还安装了签名的apk并进行了检查。一切都很好。

上传后我从playstore下载了它,然后崩溃了。

以下是堆栈跟踪:

java.lang.ExceptionInInitializerError
at java.lang.Class.newInstanceImpl(Native Method)
at java.lang.Class.newInstance(Class.java:1319)
at android.app.Instrumentation.newActivity(Instrumentation.java:1057)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2015)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2125)
at android.app.ActivityThread.access$600(ActivityThread.java:140)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1227)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4898)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.UnsatisfiedLinkError: Couldn't load hello-jni: findLibrary returned null
at java.lang.Runtime.loadLibrary(Runtime.java:365)
at java.lang.System.loadLibrary(System.java:535)
at com.somepackage.anotherpackage.SomeActivity.<clinit>(SomeActivity.java:56)
... 15 more

错误指出System.loadLibrary返回null。但是使用eclipse运行时相同的代码工作正常。

感谢您的帮助

1 个答案:

答案 0 :(得分:1)

好像你的apk缺少了libhello-jni.so。也许它在apk版本中没有打包。

如果你用一个zip软件打开你的apk,你应该有一个包含libhello-jni.so的文件夹:如果你没有它,那么你在构建时忘了一些东西。