1. 内存信息
java虚拟机运行时的数据区.png2. 对象的访问定位
Java方法执行时都是对各种对象进行操作,而这些对象都是存放在Java堆中的,Java方法中变量相关的信息是存放在虚拟机栈中的,这些变量只是一个指向对象的引用,所以方法执行时就会涉及到对象的定位。对象定位主要有两种方式:
-
使用句柄访问
使用句柄最大的好处就是对象引用中存储的是稳定的句柄地址,在对象被移动(垃圾收集中很普遍)是只会改变句柄中的实例数据指针,而对象引用本身不需要修改。
句柄方式定位对象 -
使用直接指针访问
使用直接访问的最大好处是速度快,它节省了一次指针定位的时间开销。
直接指针方式定位对象.png
3. String.intern()方法
String.intern()方法是一个Native方法(本地方法),它的作用是:如果字符串常量池中已经包含一个等于此String对象的字符串,则返回代表池中这个字符串的String对象,否则,将此String对象包含的字符串添加到常量池中,并返回此String对象的引用。
4. 垃圾收集与内存分配策略
JVM垃圾收集.png分代收集:
分代收集图示
首先,新对象的内存分配都是先在Eden区域中进行的,当Eden区域的空间不足于分配新对象时,就会触发年轻代上的垃圾回收,一般使用复制算法将存活对象复制到一个Survivor区中,同时对象年龄加1.当第二次minor gc被触发时,JVM会通过Mark算法找出所有在Eden内存区域和Survivor1内存区域存活的对象,并将他们拷贝到新的Survivor2内存区域,同时对象的年龄加1. 最后,清除所有在Eden内存区域和Survivor1内存区域的非可达对象。当对象的年龄足够大(这个年龄可以通过JVM参数进行指定),当minor gc再次发生时,它会从Survivor内存区域中升级到年老代中。当minor gc发生时,又有对象从Survivor区域升级到老年代区域中,但是老年代区域已经没有空间容纳新的对象了,那么这个时候就会触发年老代上的垃圾回收,一般采用标记-整理算法。
其他要点:大对象(需要大量连续内存空间的Java对象)直接进入老年代。
5.java虚拟机类加载机制
虚拟机类加载机制.png双亲委派模型:
从Java虚拟机的角度来讲只存在两种不同的类加载器,一种是启动类加载器,由C++实现,是虚拟机自身的一部分,另一种就是其他类加载器,这些类加载器都是有Java语言实现独立于虚拟机外部。并且全都继承自抽象类java.lang.ClassLoader。
双亲委派模型:双亲委派模型要求除了顶层的启动类加载器外,其余的类加载器都应当有自己的父类加载器,这里类加载器之间的父子关系一般不会以继承的关系来实现,而是都是用组合的关系来实现。
双亲委派模型的工作过程是:如果一个类加载器收到了类加载的请求,他首先不会自己去尝试加载这个类,而是把这个请求为派给父类的加载器去完成,每个层次的加载器都是如此,因此所有的加载请求最终都应该川大到顶层的启动类加载器中,只有当父类加载器反馈自己无法完成这个加载请求是,子加载器才会尝试自己去加载。
网友评论