Android 加载我的库

Android 加载我的库,android,Android,这是我用过的项目: 当我试图运行我的项目时,我在加载我的库“pdfrender”时遇到问题 下面是导致问题的行:System.loadLibrary(“pdfrender”) 在我的项目中,我有一个名为jni的floader,其中包含库pdfrender.c 这是我的日志: 02-28 10:57:55.241: E/AndroidRuntime(596): java.lang.ExceptionInInitializerError 02-28 10:57:55.241: E/AndroidRu

这是我用过的项目:

当我试图运行我的项目时,我在加载我的库“pdfrender”时遇到问题 下面是导致问题的行:
System.loadLibrary(“pdfrender”)
在我的项目中,我有一个名为jni的floader,其中包含库pdfrender.c

这是我的日志:

02-28 10:57:55.241: E/AndroidRuntime(596): java.lang.ExceptionInInitializerError
02-28 10:57:55.241: E/AndroidRuntime(596):  at de.hilses.droidreader.DroidReaderActivity.onCreate(DroidReaderActivity.java:108)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.Activity.performCreate(Activity.java:4465)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.ActivityThread.access$600(ActivityThread.java:123)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.os.Handler.dispatchMessage(Handler.java:99)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.os.Looper.loop(Looper.java:137)
02-28 10:57:55.241: E/AndroidRuntime(596):  at android.app.ActivityThread.main(ActivityThread.java:4424)
02-28 10:57:55.241: E/AndroidRuntime(596):  at java.lang.reflect.Method.invokeNative(Native Method)
02-28 10:57:55.241: E/AndroidRuntime(596):  at java.lang.reflect.Method.invoke(Method.java:511)
02-28 10:57:55.241: E/AndroidRuntime(596):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-28 10:57:55.241: E/AndroidRuntime(596):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-28 10:57:55.241: E/AndroidRuntime(596):  at dalvik.system.NativeStart.main(Native Method)
02-28 10:57:55.241: E/AndroidRuntime(596): Caused by: java.lang.UnsatisfiedLinkError: Couldn't load pdfrender: findLibrary returned null
02-28 10:57:55.241: E/AndroidRuntime(596):  at java.lang.Runtime.loadLibrary(Runtime.java:365)
02-28 10:57:55.241: E/AndroidRuntime(596):  at java.lang.System.loadLibrary(System.java:535)
02-28 10:57:55.241: E/AndroidRuntime(596):  at de.hilses.droidreader.PdfRender.<clinit>(PdfRender.java:111)
02-28 10:57:55.241: E/AndroidRuntime(596):  ... 15 more
02-28 10:57:55.241:E/AndroidRuntime(596):java.lang.exceptionininitializerror
02-28 10:57:55.241:E/AndroidRuntime(596):在de.hilses.droidreader.DroidReaderActivity.onCreate(DroidReaderActivity.java:108)
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.Activity.performCreate(Activity.java:4465)上
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)上
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)上
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.ActivityThread.access$600(ActivityThread.java:123)
02-28 10:57:55.241:E/AndroidRuntime(596):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
02-28 10:57:55.241:E/AndroidRuntime(596):在android.os.Handler.dispatchMessage(Handler.java:99)上
02-28 10:57:55.241:E/AndroidRuntime(596):在android.os.Looper.loop(Looper.java:137)上
02-28 10:57:55.241:E/AndroidRuntime(596):位于android.app.ActivityThread.main(ActivityThread.java:4424)
02-28 10:57:55.241:E/AndroidRuntime(596):位于java.lang.reflect.Method.Invokenactive(本机方法)
02-28 10:57:55.241:E/AndroidRuntime(596):位于java.lang.reflect.Method.invoke(Method.java:511)
02-28 10:57:55.241:E/AndroidRuntime(596):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-28 10:57:55.241:E/AndroidRuntime(596):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-28 10:57:55.241:E/AndroidRuntime(596):在dalvik.system.NativeStart.main(本机方法)
02-28 10:57:55.241:E/AndroidRuntime(596):原因:java.lang.UnsatifiedLink错误:无法加载pdfrender:findLibrary返回null
02-28 10:57:55.241:E/AndroidRuntime(596):在java.lang.Runtime.loadLibrary(Runtime.java:365)上
02-28 10:57:55.241:E/AndroidRuntime(596):位于java.lang.System.loadLibrary(System.java:535)
02-28 10:57:55.241:E/AndroidRuntime(596):在de.hilses.droidreader.PdfRender.(PdfRender.java:111)
02-28 10:57:55.241:E/AndroidRuntime(596):。。。还有15个
  • >无法加载(库)pdfrender
如果使用eclipse生成舒尔,则生成路径中的库pdfrender将标记为导出(设置库之前的复选框)


然后它应该包含在构建apk文件中

最后我找到了我们必须安装ndk android和cygwin的解决方案。然后我们就可以从.c文件构建.so

关于更多的解释,你可以看到这一点,这对我很有帮助:

请告诉我,我是Eclipse新手,我该怎么做。我在jni文件夹中找到了pdfrender.c!!我知道如何导入.jar库,而不是.c??我一直在阅读开源项目的自述文件,他们说,为了构建DroidReader,您需要:-DroidReader的源代码,但您已经管理好了…-MuPDF软件/库的源代码-libjpeg的源代码-freetype2的源代码-Android本机开发工具包(NDK)-当然还有Android SDK。对不起,我没有将java与本机c/NDK相结合的经验