Java类加载器(ClassLoader)的实际使用场景有哪些

实际使用场景有:1、依赖冲突;2、热加载;3、热部署;4、加密保护。依赖冲突指基于maven的pom进制可以方便的进行依赖管理,但是由于maven依赖的传递性,会导致我们的依赖错综复杂,这样就会导致引入类冲突的问题。

Java类加载器(ClassLoader)的实际使用场景有哪些-Worktile社区

1、依赖冲突

做过多人协同开发的大型项目的同学可能深有感触。基于maven的pom进制可以方便的进行依赖管理,但是由于maven依赖的传递性,会导致我们的依赖错综复杂,这样就会导致引入类冲突的问题。最典型的就是NoSuchMethodException异常了。

该如何避免依赖冲突的问题呢?首先我们用一个非常简单的场景来描述为什么会出现类冲突的问题。

某个业务引用了消息中间件(例如metaq)和微服务中间件(例如dubbo),这两个中间件也同时引用了fastjson-2.0和fastjson-3.0版本,而业务自己本身也引用了fastjson-1.0版本。这三个版本表现不同之处在于classA类中方法数目不相同,我们根据maven依赖处理的机制,引用路径最短的fastjson-1.0会真正作为应用最终的依赖,其它两个版本的fastjson则会被忽略,那么中间件在调用method2()方法的时候,则会抛出方法找不到异常。

那如何解决包冲突的问题呢?答案就是pandora(潘多拉),通过自定义类加载器,为每个中间件自定义一个加载器,这些加载器之间的关系是平行的,彼此没有依赖关系。这样每个中间件的classloader就可以加载各自版本的fastjson。因为一个类的全限定名以及加载该类的加载器两者共同形成了这个类在JVM中的惟一标识,这也是阿里pandora实现依赖隔离的基础。

2、热加载

在开发项目的时候,我们需要频繁的重启应用进行程序调试,但是java项目的启动少则几十秒,多则几分钟。如此慢的启动速度极大地影响了程序开发的效率,那是否可以快速的进行启动,进而能够快速的进行开发验证呢?答案也是肯定的,通过classloader我们可以完成对变更内容的加载,然后快速的启动。

常用的热加载方案有好几个,接下来我们介绍下spring官方推荐的热加载方案,即spring boot devtools。

首先我们需要思考下,为什么重新启动一个应用会比较慢,那是因为在启动应用的时候,JVM虚拟机需要将所有的应用程序重新装载到整个虚拟机。可想而知,一个复杂的应用程序所包含的jar包可能有上百兆,每次微小的改动都是全量加载,那自然是很慢了。那么我们是否可以做到,当我们修改了某个文件后,在JVM中替换到这个文件相关的部分而不全量的重新加载呢?而spring boot devtools正是基于这个思路进行处理的。

3、热部署

热部署本质其实与热加载并没有太大的区别,通常我们说热加载是指在开发环境中进行的classloader加载,而热部署则更多是指在线上环境使用classloader的加载机制完成业务的部署。所以这二者使用的技术并没有本质的区别。那热部署除了与热加载具有发布更快之外,还有更多的更大的优势就是具有更细的发布粒度。我们可以想像以下的一个业务场景。

假设某个营销投放平台涉及到4个业务方的开发,需要对会场业务进行投放。而这四个业务方的代码全部都在一个应用里面。因此某个业务方有代码变更则需要对整个应用进行发布,同时其它业务方也需要跟着回归。因此每个微小的发动,则需要走整个应用的全量发布。这种方式带来的稳定性风险估且不说,整个发布迭代的效率也可想而知了。这在整个互联网里,时间和效率就是金钱的理念下,显然是无法接受的。

那么我们完全可以通过类加载机制,将每个业务方通过一个classloader来加载。基于类的隔离机制,可以保障各个业务方的代码不会相互影响,同时也可以做到各个业务方进行独立的发布。其实在移动客户端,每个应用模块也可以基于类加载,实现插件化发布。本质上也是一个原理。

4、加密保护

众所周期,基于java开发编译产生的jar包是由.class字节码组成,由于字节码的文件格式是有明确规范的。因此对于字节码进行反编译,就很容易知道其源码实现了。因此大致会存在如下两个方面的诉求。例如在服务端,我们向别人提供三方包实现的时候,不希望别人知道核心代码实现,我们可以考虑对jar包进行加密,在客户端则会比较普遍,那就是我们打包好的apk的安装包,不希望被人家反编译而被人家翻个底朝天,我们也可以对apk进行加密。

延伸阅读:

什么是Java类加载器?

Java类加载器(Java Classloader)是Java运行时环境(Java Runtime Environment)的一部分,负责动态加载Java类到Java虚拟机的内存空间中。

Java类加载器(英语:Java Classloader)是Java运行时环境(Java Runtime Environment)的一部分,负责动态加载Java类到Java虚拟机的内存空间中。类通常是按需加载,即名列前茅次使用该类时才加载。由于有了类加载器,Java运行时系统不需要知道文件与文件系统。学习类加载器时,掌握Java的委派概念很重要。

每个Java类必须由某个类加载器装入到内存。Java程序可以利用外部库(即由其他作者编写的软件库)。

Java EE(JEE)应用程序服务器典型地用树状的一组类装载器从已部署的WAR或EAR文档中装入类。这使得应用程序之间彼此隔离,但共享已部署模块。servlet container一般被实现为多个类装载器。

Java运行环境(Java Runtime Environment,简称JRE)是一个软件,由太阳微系统所研发,JRE可以让计算机系统运行Java应用程序(Java Application)。

JRE的内部有一个Java虚拟机(Java Virtual Machine,JVM)以及一些标准的类别函数库(Class Library)。

文章标题:Java类加载器(ClassLoader)的实际使用场景有哪些,发布者:小编,转载请注明出处:https://worktile.com/kb/p/37333

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小编小编认证作者
上一篇 2023年2月7日 下午9:53
下一篇 2023年2月7日 下午9:56

相关推荐

  • 主板用什么编程

    主板用什么编程 主板编程主要依赖于3、 低级编程语言和专有软件。其中较为突出的是低级编程语言的应用。它们通常包括汇编语言和C语言,这些语言能够直接与硬件交互,通常用于开发固件(如BIOS或UEFI),这是主板正常工作所需的基础软件。低级编程语言能够提供与硬件直接沟通的能力,使开发者能够精确控制硬件行…

    2024年5月2日
    3700
  • web编程学习什么

    学习Web编程主要涉及三个方面:1、前端开发技术、2、后端开发技术、3、数据库知识。其中,深入理解前端开发 是构建网站视觉和交互的基础。它涵盖了HTML、CSS和JavaScript等技术,这些是开发任何Web应用程序或网站时的必备工具。特别是JavaScript,它通过增加动态内容来丰富用户体验,…

    2024年5月2日
    4700
  • 手机系统用什么编程语言

    手机系统大多使用C、C++与Java三种编程语言。 其中,C语言 因其接近硬件层级、运行效率高而被广泛应用于系统开发。它允许开发人员直接与设备硬件交互,这在操作系统底层开发中尤为重要。C语言使得开发者能够通过精细的资源管理和高效的代码执行来优化系统性能。 I、C语言在手机系统中的应用 C语言在手机操…

    2024年5月7日
    1100
  • 编程猫用什么编程语言

    编程猫 主要采用了 1、Scratch、2、Python、3、C++,同时还支持 HTML5 和 JavaScript。作为面向儿童和青少年的编程学习平台,编程猫通过这些编程语言的逐级学习来提升用户的编程技能。尤其是 Scratch——一种由麻省理工学院媒体实验室开发的图形化编程语言,它通过拖拽编程…

    2024年5月1日
    4400
  • 并行编程注意什么

    并行编程在设计和实现时应注重避免数据竞争、确保线程安全及有效利用础资源。 其中,数据竞争问题尤为突出,随着多线程访问共享数据时如果没有适当的同步机制,会导致程序执行结果的不确定性。为此,开发者通常需确保通过锁、信号量等同步原语来协调线程之间的交互,保持数据的一致性和完整性。 并行编程的关键考虑因素 …

    2024年5月2日
    3500
  • 会编程有什么用

    会编程的用处多种多样,主要可以总结为3个方面:1、 提高解决问题的能力、 2、开拓就业机会、3、促进个人创新。 其中,提高解决问题的能力是编程最直接的好处。通过编程,人们学会了如何分析问题、设计算法以及优化解决方案。这不仅仅限于计算机相关问题,这种问题解决能力是通用的,能够应用于生活和工作的诸多方面…

    2024年4月27日
    3500
  • 机器人编程有什么等级比赛

    机器人编程比赛主要包括1、国际青少年机器人竞赛(WRO)和2、FIRST机器人大赛。第一类,WRO,致力于激发青少年对科学、技术、工程和数学(STEM)领域的兴趣。在这个竞赛中,参与者需设计、构建和编程机器人来完成指定任务,既考验了他们的技术能力,也考查了团队合作和创新思维。 一、国际青少年机器人竞…

    2024年4月27日
    4000
  • 有什么图形编程

    图形编程广泛应用于游戏开发、数据可视化和计算机图形设计。主流的图形编程技术包括1、DirectX、2、OpenGL、3、WebGL、4、Vulkan。 OpenGL是一套广泛应用于多平台的图形编程接口,它提供了一系列函数调用,使得开发者可以在更高的抽象层次上绘制2D和3D图像。它的主要优势在于其跨平…

    2024年5月2日
    2700
  • 如何在百度搜索引擎中进行优化

    在百度搜索引擎中进行优化的步骤:1、选择合适的关键词;2、提升关键词密度;3、优化页面标题和描述;4、优化内部链接;5、建立外部链接;6、提供有价值的内容;7、优化页面加载速度;8、使用语义化标签;9、移动端优化;10、定期更新内容;11、监控竞争对手的SEO策略;12、与用户建立良好的关系。

    2023年11月11日
    41100
  • 编程里面会用什么方程代替

    在编程中,使用各种数学方程来模拟现实世界问题是常见的实践。例如,线性方程经常用来预测值的增长或下降,而在处理更加复杂的情况时,可能会使用多项式或者指数方程。复杂算法中常见的是利用差分方程来递推序列值,或者在金融领域对股票价格模型应用随机微分方程。此外,在机器学习中,经常会用到逻辑回归方程来进行二分类…

    2024年4月27日
    4900

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部