在我的android项目中,我使用了一个外部jar库,它使用了一个运行时库libiconv.so。我将库包含在项目的lib目录中。这个库包含在hirarcy目录下的所有三个架构中。
libs>
armeabi>libiconv.so
armeabi-v7a>libiconv.so
x86>libiconv.so
但是我得到了日志猫记录的异常:
05-23 12:18:58.857 3081-3081/? E/AndroidRuntime: FATAL EXCEPTION: main
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:1054)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
at android.app.ActivityThread.access$600(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5041)
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:793)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.UnsatisfiedLinkError: Couldn't load libiconv.so from loader dalvik.system.PathClassLoader[dexPath=/data/app/com.tariq.buynow-1.apk,libraryPath=/data/app-lib/com.tariq.buynow-1]: findLibrary returned null
at java.lang.Runtime.loadLibrary(Runtime.java:365)
at java.lang.System.loadLibrary(System.java:535)
at com.tariq.buynow.CameraActivity.<clinit>(CameraActivity.java:30)
Java:Java: 30是:
static { System.loadLibrary("libiconv.so"); }
我也试过
static { System.loadLibrary("iconv"); }
是因为我刚进入android studio,所以gradle的配置有问题,还是因为错误源是其他原因?
最佳答案
我在尝试使用zbar sdk时遇到了同样的问题。您很可能需要编辑build.gradle以确保本地库包含在apk中。我就是这样解决你的问题的:https://stackoverflow.com/a/16993006/2221876