技术文摘
Java 史上三次破坏双亲委派模型分别是哪些?
Java 史上三次破坏双亲委派模型分别是哪些?
在 Java 的发展历程中,双亲委派模型是类加载机制的重要原则,但也存在三次被破坏的情况。
第一次破坏发生在 JNDI 服务中。JNDI 是 Java 命名和目录接口,其目的是为了整合不同的命名服务和目录服务。由于 JNDI 中的代码需要调用由独立厂商实现并部署在应用程序的 ClassPath 下的代码,而启动类加载器无法加载这些类,所以不得不破坏双亲委派模型,使用线程上下文类加载器来加载。
第二次破坏是为了支持热部署。热部署要求在运行时重新加载修改后的类,而传统的双亲委派模型无法满足这一需求。在这种情况下,通过自定义类加载器来实现类的重新加载,从而打破了双亲委派模型的限制。
第三次破坏则与 OSGi 框架有关。OSGi 是一个动态化模块化的 Java 框架。在 OSGi 中,每个模块(Bundle)都有自己独立的类加载器,并且这些类加载器之间的关系不再是传统的双亲委派模型。模块之间的类共享和隔离通过特定的规则和机制来实现,这再次打破了双亲委派模型。
这些对双亲委派模型的破坏并非是对其原则的否定,而是在特定场景下为了满足更复杂的需求而做出的灵活调整。它们展示了 Java 技术在不断发展和应对新挑战时的创新和适应能力。
理解这三次破坏,有助于我们更深入地理解 Java 类加载机制的本质,以及在不同场景下如何灵活运用和优化类加载策略,从而更好地开发和优化 Java 应用程序。也让我们看到 Java 作为一种成熟的编程语言,在保持稳定性和兼容性的基础上,不断演进和完善自身的机制,以适应日益复杂和多样化的应用需求。
TAGS: Java 技术 Java 发展历程 Java 双亲委派模型 Java 核心原理
- 应对 App 与网站常见的几种攻击类型之方法
- 微信小程序服务器域名配置图文详解
- vscode 中 eslint 插件失效问题与解决办法
- ArcGIS Pro 中基于字段的融合与拆分操作步骤
- XPath 的定义、语法基础、示例运用与高级技法
- vscode eslint 插件报错:Invalid ecmaVersion 导致的解析错误
- Notepad++ 文本比较插件 Compare 深度解析(最新免费)
- 解决 padding 和 border 撑大 div 的方法
- VS Code 配置前端环境与运行的详细指引
- Hexo 博客实现 HTTPS 的 SSL 证书启用过程
- 前端常见性能优化实用方法有哪些
- .gitignore 文件助力简化 Git 仓库管理
- 油猴脚本开发全析及油猴爬虫脚本实例解读
- HTML 中 CSS:hover 选择器对各类元素样式的改变
- VSCode 中 Clang-Format 插件的安装配置与使用总结