引言
以Student a = new Student();为例,
——》JVM讲的是这行代码为什么能运行?怎么运行的?怎么处理会运行的更好?
——》上面的代码能运行的基本条件就是有一个Student类
——》JVM也能解决当有Student类时,为什么new Student()可以实现,new Student1()不可以实现。
Student a = new Student();
——》创建了Student对象,就需要划分空间
——》JVM是怎么分配空间的?
1、指针碰撞法(指针不断向后移动)
- 分为若干个小块,按顺序分配
- 优点:操作非常简单
- 缺点:要求空间一定是规整的
假设Java堆中内存是绝对规整的,所有被使用过的内存都被放在一边,空闲的内存被放在另一边,中间放着一个指针作为分界点的指示器,那所分配内存就仅仅是把那个指针向空闲空间方向挪动一段与对象大小相等的距离,这种分配方式称为“指针碰撞”。
2、空闲列表
- 根据需要的空间分配
- 需要一个列表
- 会出现空间碎片问题
如果Java堆中的内存并不是规整的,已被使用的内存和空闲的内存相互交错在一起,那就没有办法简单地进行指针碰撞了,虚拟机就必须维护一个列表,记录上哪些内存块是可用的,在分配的时候从列表中找到一块足够大的空间划分给对象实例,并更新列表上的记录,这种分配方式称为“空闲列表”
注: 选择哪种分配方式由Java堆是否规整决定,而Java堆是否规整又由所采用的垃圾收集器是否带有空间压缩整理(Compact)的能力决定。