在我正在学习的一本书中,他们展示了这段 Java 代码:
Class c = ClassLoader.getSystemClassLoader().loadClass(name);
Class type = this.getClass().getClassLoader().loadClass(name);
Object obj = type.newInstance();
此代码用于动态加载 Java 类。这本书接着说:
unloading modules raises an issue. A class loader cannot unload a class. Unloading a class requires unloading the class loader itself. This is why programmers .. tend to define several class loaders.
使用这样的代码有什么好处?自主计算的概念通常是——“自主系统管理”。这与 Java 程序如何受 JVM 控制有何关系?
来源:Autonomic Computing Principles Design (by Lalanda) 第 166 页
最佳答案
好处是您可以在运行时决定实际加载和使用的类。对于只有一个类的单一实现的简单 Java 程序没有任何好处。
像 Osgi(Eclipse 的基础)这样的复杂环境为每个模块使用单独的类加载器。这带来了灵 active 以及在运行时替换模块的可能性。
另一个“经典”用例是在运行时加载数据库驱动程序。您可能想要连接到 MySQL 数据库或 Oracle,并且两者都使用不同的 JDBCDriver 实现。
添加:
可以找到 Alex Blewitt 的一篇非常好的文章,讨论了 eclipse/osgi 类加载概念 here .
根据我自己的编码经验,我将 eclipse 插件用于企业级网络监控项目。监控基本上与不断抓取网络上的一些资源有关。每个此类资源都由监视器插件的实现监视。并非所有资源都由我们控制,因此当它们发生变化时,我们必须调整处理该资源的插件。当我们针对新插件模块卸载旧插件模块时,整个监控应用程序可以继续运行。全部在运行时,几乎没有停机时间(仅针对需要交换的模块) 当然,我对每个插件的类加载器的使用是通过使用 Eclipse 富客户端平台 (RCP) 隐式使用的。您只需要指定哪个插件依赖于哪个插件,然后由 RCP 平台完成实际的类加载。
像 Tomcat 这样的 Web 服务器使用相同的方法,尽管我对 Tomcat 没有太多经验。
直接实现动态类加载系统可能是一个很好的练习,但对于现实世界的应用程序,我肯定会研究生产级实现,比如 Eclipse RCP或 Apache Karaf
如果您想更进一步并需要在集群中运行您的插件,您可能需要查看 Gyrex
我不能在这里分享我的代码,但这里有一些很好的起点和代码示例:
关于java - 以下 Java 代码在自主计算领域有何用处?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31362535/