Memory Model -- 04 -- Java内存模型(四、堆)

在这里插入图片描述


一、Java 堆 (java Heap)

  • 对于大多数应用来说,Java 堆 (Java Heap) 是 Java 虚拟机所管理的内存中最大的一块,Java 堆是被所有线程共享的一块内存区域,在虚拟机启动时创建

    • 此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存

    • 这一点在 Java 虚拟机规范中的描述是:所有的对象实例以及数组都要在堆上分配,但是随着 JIT 编译器的发展与逃逸分析技术逐渐成熟,栈上分配、标量替换优化技术将会导致一些微妙的变化发生,所有的对象都分配在堆上也渐渐变得不是那么 “绝对” 了

  • Java 堆是垃圾收集器管理的主要区域,因此很多时候也被称做 “GC 堆” (Garbage Collected Heap)

    • 从内存回收的角度看,由于现在收集器基本采用分代收集算法,所以 Java 堆还可以细分为:新生代和老年代;再细致一点的有 Eden 空间、From Survivor 空间、To Survivor 空间

    • 从内存分配的角度看,线程共享的 Java 堆中可能划分出多个线程私有的分配缓冲区 (Thread Local Allocation Buffer,TLAB)

  • 不过无论如何划分,都与存放内容无关;无论哪个区域,存储的仍然是对象实例,进一步划分的目的是为了更好地回收内存,或者更快地分配内存

  • 根据 Java 虚拟机规范的约定,Java 堆可以处理物理上不连续的内存空间,只要逻辑上是连续的即可,就像我们的磁盘一样。在现实中,既可以是现成固定大小的,也可以是扩展的,不过当前主流的虚拟机都是按照可扩展来实现的 (通过 -Xmx 和 -Xms 控制)。如果在 Java 堆中没有完成实例分配,并且堆也无法扩展时,将会抛出 OutOfMemoryError 异常


二、归纳总结

  • Java 堆

    • 是 Java 虚拟机所管理的内存中最大的一块

    • 被所有线程所共享,用于存放对象实例

    • 可以处理物理上不连续的内存空间,只要逻辑上是连续的即可

  • Java 堆的划分

    • 为了更好地回收内存,或者更快地分配内存
发布了106 篇原创文章 · 获赞 83 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/Goodbye_Youth/article/details/102819422