2013-04-30 107 views
0

我上傳了一個應用程序到playstore。該應用程序包含本機C代碼。我使用NDK成功編譯了它,創建了簽名的apk。我還安裝了已簽名的apk並進行了檢查。一切正常。NDK應用程序在Play商店上傳後崩潰

上傳後,我從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

好像您的APK缺少libhello-jni.so。也許它在apk編譯時沒有打包。

如果你用zip軟件打開你的apk,你應該有一個包含libhello-jni.so的文件夾庫:如果你沒有它,那麼你在構建時忘了一些東西。

+0

我檢查了簽名的apk並提取了它。它有libhello-jni.so。我不明白如果相同的代碼上傳到playstore,它不能執行 – user2335691 2013-04-30 12:18:18

相關問題