【发布时间】:2014-07-07 13:28:56
【问题描述】:
我有这个代码。 我在文件夹 data/data/com.xxx.xxx/files 中手动添加了 rectanglecalcul.jar 并且日志确认文件存在是真的。这是我项目的第二部分,在第一部分中,我尝试从我的服务器下载 JAR 文件(它还不能正常工作,这就是我自己在 AVD 中添加它的原因)。
try {
File f = new File(c.getFilesDir().getPath()
+ "/rectanglecalcul.jar");
Log.i("File", "" + f.exists());
URLClassLoader u = new URLClassLoader(new URL[] { f.toURI()
.toURL() });
Class<?> c = u.loadClass("perimetre.calcul");
Constructor<?> constru = c.getConstructor(int.class,
int.class);
Object o = constru.newInstance(2, 2);
Method m = c.getMethod("resultat", int.class, int.class);
m.setAccessible(true);
m = null;
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalAccessException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InvocationTargetException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (NoSuchMethodException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (InstantiationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
其实是在Java项目上工作,但是我在Android项目上试的时候,调用方法loadclass时出现NullPointerExecption。
我尝试在外部和内部存储上添加 READ & WRITE 权限,但没有帮助。
这里是 LogCat:
07-07 06:57:07.644: E/AndroidRuntime(11385): java.lang.NullPointerException
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.net.URLClassLoader.getPermissions(URLClassLoader.java:614)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.security.SecureClassLoader.getPD(SecureClassLoader.java:140)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:93)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.net.URLClassLoader.access$600(URLClassLoader.java:55)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.net.URLClassLoader$URLJarHandler.createClass(URLClassLoader.java:364)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.net.URLClassLoader$URLJarHandler.findClass(URLClassLoader.java:303)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.net.URLClassLoader.findClass(URLClassLoader.java:748)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
07-07 06:57:07.644: E/AndroidRuntime(11385): at com.example.androidimportjar.MainActivity$1.onClick(MainActivity.java:79)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.view.View.performClick(View.java:4438)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.view.View$PerformClick.run(View.java:18422)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.os.Handler.handleCallback(Handler.java:733)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.os.Handler.dispatchMessage(Handler.java:95)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.os.Looper.loop(Looper.java:136)
07-07 06:57:07.644: E/AndroidRuntime(11385): at android.app.ActivityThread.main(ActivityThread.java:5017)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.lang.reflect.Method.invokeNative(Native Method)
07-07 06:57:07.644: E/AndroidRuntime(11385): at java.lang.reflect.Method.invoke(Method.java:515)
07-07 06:57:07.644: E/AndroidRuntime(11385): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
07-07 06:57:07.644: E/AndroidRuntime(11385): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
07-07 06:57:07.644: E/AndroidRuntime(11385): at dalvik.system.NativeStart.main(Native Method)
我在这方面花了很多时间,尝试了很多解决方法,但没有任何效果。 所以我需要帮助!
如有英文错误,敬请见谅!
【问题讨论】:
-
你注意到JarClassLoader了吗?
标签: java android nullpointerexception android-permissions urlclassloader