时间:2021-05-20
在讲解动态加载类之前呢,我们先弄清楚为什么要动态加载类,静态加载不行吗?我们可以看下面的实例:
我在文件夹里写了Office.java 类和 Word.java类,如下:
Office.java
class Office{ public static void main(String[] args){ if(args[0].equals("Word")){ Word w = new Word(); w.start(); } if(args[0].equals("Excel")){ Excel e = new Excel(); e.start(); } }}Word.java
class Word{ public void start(){ System.out.println("Word Start"); }}此时我们编译一下Office.java 文件:
编译会报错,这当然没问题,因为确实没有写Excel.java类。
但是这个Excel类我们一定会用到吗?如果这个Excel类需要很久才能写出来,在此我们也不能使用其他功能吗?后面如果一个类出问题了,这个系统是不是就瘫痪了?
所以这就体现出动态加载类的好处了,动态加载类是按需加载的,你需要什么类,就加载什么类,一个类的状态,不会影响到另一个类的使用。
所以我们可以将Office类改造如下:
class Office{ public static void main(String[] args){ try{ Class c = Class.forName(args[0]); Word w = (Word)c.newInstance(); w.start(); } catch(Exception e){ e.printStackTrace(); } }}虽然我们还是没有写Excel类,但此时我们再编译Office.java文件,编译通过;
运行一下:
成功按照我们预想的结果运行,这样Word类就可以单独运行。
但是这样还是不够规范,因为现在只能加载Word类类型的类文件,为了使程序有更好的扩展性,我们添加一个接口,只有让所有的功能类实现该接口即可。完善如下:
OfficeAble.java
interface OfficeAble{ public void start();}Office.java
class Office{ public static void main(String[] args){ try{ Class c = Class.forName(args[0]); OfficeAble oa = (OfficeAble)c.newInstance(); oa.start(); } catch(Exception e){ e.printStackTrace(); } }}Word.java
class Word implements OfficeAble{ public void start(){ System.out.println("Word Start"); }}这样改造之后,我后面要添加一个Excel类,乃至添加其他的类,只需要实现OfficeAble接口就可以了,不需要改动Office这个类和其他的功能类,扩展性很强,这就是动态加载的优势。
总结
到此这篇关于Java动态加载类的文章就介绍到这了,更多相关Java动态加载类内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
详解javaJDK动态代理类分析(java.lang.reflect.Proxy)/***JDK动态代理类分析(java.lang.reflect.Proxy使
java动态加载的实现代码Java动态加载类的意义和目的:Java动态加载类主要是为了不改变主程序代码,通过修改配置文件就可以操作不同的对象执行不同的功能。主要
类加载器java类加载器就是在运行时在JVM中动态地加载所需的类,java类加载器基于三个机制:委托,可见,单一。把classpath下的那些.class文件加
java详解类加载器的双亲委派及打破双亲委派一般的场景中使用Java默认的类加载器即可,但有时为了达到某种目的又不得不实现自己的类加载器,例如为了达到类库的互相
详解java中继承关系类加载顺序问题实例代码:/***Createdbyfeion2017/5/31.*/publicclassSonClassextendsP