
jvm
文章平均质量分 93
饭团煲
学习记录
展开
-
JVM类加载器
类加载器虽然只用于实现类的加载动作,但它在Java程序中起到的作用却远超类加载阶段。对于任意一个类,都必须由加载它的类加载器和这个类本身一起共同确立其在Java虚拟机中的唯一性,每一个类加载器,都拥有一个独立的类名称空间。这句话可以表达得更通俗一些:比较两个类是否“相等”,只有在这两个类是由同一个类加载器加载的前提下才有意义,否则,即使这两个类来源于同一个Class文件,被同一个Java虚拟机加载,只要加载它们的类加载器不同,那这两个类就必定不相等。这里所指的“相等”,包括代表类的Class对象的equa原创 2023-08-31 21:47:28 · 568 阅读 · 0 评论 -
JVM类加载机制
从概念上讲,这些变量所使用的内存都应当在方法区中进行分配,但必须注意到方法区本身是一个逻辑上的区域,在JDK 7及之前,HotSpot使用永久代来实现方法区时,实现是完全符合这种逻辑概念的;而在JDK 8及之后,类变量则会随着Class对象一起存放在Java堆中,这时候“类变量在方法区”就完全是一种对逻辑概念的表述了。原创 2023-08-31 17:00:16 · 613 阅读 · 0 评论 -
JVM垃圾回收算法和CMS垃圾收集器
垃圾收集需要完成的三件事情:引用计数法:在对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加一;当引用失效时,计数器值就减一;任何时刻计数器为零的对象就是不可能再被使用的。客观地说,引用计数算法(Reference Counting)虽然占用了一些额外的内存空间来进行计数,但它的原理简单,判定效率也很高,在大多数情况下它都是一个不错的算法。但是,在Java领域,至少主流的Java虚拟机里面都没有选用引用计数算法来管理内存,主要原因是,这个看似简单的算法有很多例外情况要考虑,必须要配合大量额外处原创 2023-08-31 14:12:38 · 627 阅读 · 0 评论 -
JVM虚拟机对象探秘
以便在极小的空间内存储尽量多的数据,根据对象的状态复用自己的存储空间。例如在32位的HotSpot虚拟机中,如对象未被同步锁锁定的状态下,Mark Word的32个比特存储空间中的25个比特用于存储对象哈希码,4个比特用于存储对象分代年龄,2个比特用于存储锁标志位,1个比特固定为0,在其他状态(轻量级锁定、重量级锁定、GC标记、可偏向)下对象的存储内容如下图所示。对象头的另外一部分是。原创 2023-08-31 11:00:24 · 323 阅读 · 0 评论 -
Java虚拟机内部组成
在GC开始的时候,对象只会存在于Eden区和名为From的Survivor区,To区是空的,一次MinorGc过后,Eden区和SurvivorFrom区存活的对象会移动到SurvivorTo区中,然后会清空Eden区和SurvivorFrom区,并对存活的。Java程序是多线程运行的,比如当我们执行线程A的11行代码,突然出现优先级更高的线程B,那么线程A会被挂起,线程B执行结束后继续执行线程A,那么从哪里开始继续运行呢?本地方法栈:本地方法调用时,本地方法栈会给当前线程分配一块栈内存来运行本地方法 (原创 2023-08-30 15:39:53 · 292 阅读 · 0 评论