技术文摘
Java 史上三次破坏双亲委派模型分别是哪些?
Java 史上三次破坏双亲委派模型分别是哪些?
在 Java 的发展历程中,双亲委派模型是类加载机制的重要原则,但也存在三次被破坏的情况。
第一次破坏发生在 JNDI 服务中。JNDI 是 Java 命名和目录接口,其目的是为了整合不同的命名服务和目录服务。由于 JNDI 中的代码需要调用由独立厂商实现并部署在应用程序的 ClassPath 下的代码,而启动类加载器无法加载这些类,所以不得不破坏双亲委派模型,使用线程上下文类加载器来加载。
第二次破坏是为了支持热部署。热部署要求在运行时重新加载修改后的类,而传统的双亲委派模型无法满足这一需求。在这种情况下,通过自定义类加载器来实现类的重新加载,从而打破了双亲委派模型的限制。
第三次破坏则与 OSGi 框架有关。OSGi 是一个动态化模块化的 Java 框架。在 OSGi 中,每个模块(Bundle)都有自己独立的类加载器,并且这些类加载器之间的关系不再是传统的双亲委派模型。模块之间的类共享和隔离通过特定的规则和机制来实现,这再次打破了双亲委派模型。
这些对双亲委派模型的破坏并非是对其原则的否定,而是在特定场景下为了满足更复杂的需求而做出的灵活调整。它们展示了 Java 技术在不断发展和应对新挑战时的创新和适应能力。
理解这三次破坏,有助于我们更深入地理解 Java 类加载机制的本质,以及在不同场景下如何灵活运用和优化类加载策略,从而更好地开发和优化 Java 应用程序。也让我们看到 Java 作为一种成熟的编程语言,在保持稳定性和兼容性的基础上,不断演进和完善自身的机制,以适应日益复杂和多样化的应用需求。
TAGS: Java 技术 Java 发展历程 Java 双亲委派模型 Java 核心原理
- Flex 布局下 overflow-scroll 失效的解决办法
- HTML 和 CSS 打造可交互圆盘式环形图的方法
- for循环中用js arrays.push添加元素为何会重复输出
- JavaScript 函数挑战
- CSS中box-shadow设置透明度阴影的正确用法
- 图片宽度怎样自适应容器宽度
- Vue3中获取元素margin-top值的方法
- 反应疲劳:部分开发人员继续前进的原因
- Flex布局下overflow失效问题及让子元素溢出出现滚动条的方法
- 为何点击按钮不为空时点击一次正常,加入 my_function() 后就不行了
- 把字符串中的HTML文本转成可用的HTML标签的方法
- 关闭Bootstrap左侧导航栏并让右侧内容全屏显示的方法
- 用户登录过期自动跳转、重新登录及权限控制的实现方法
- .NET WebAPI 上传图片时 FileData 为 0 问题的解决办法
- 登录过期后怎样实现自动续期与权限管理