Java内存管理(一)--内存分区

出处:http://blog.sina.com.cn/s/blog_7d0e75ab01016vio.html

 Java提供的内存管理机制是一把双刃剑。好处是java虚拟机帮你完成了几乎所有内存管理的工作,你可以不用再去为每个new对象操作来施放内存。弊端是你将几乎不再拥有对象内存管理的权限(因为你不用做这些工作),长此以往我们就淡漠了java虚拟机管理内存的机制,而 导致我们遇到一些内存泄露的问题时却无从下手,所以了解虚拟机是这样管理内存的对于一名Java程序员来说很重要。


     水平有限,不足之处欢迎拍砖。第一篇先说说Java虚拟机的内存分区和各区的职责。

     Java虚拟机所管理的运行时内存包含以下五个区域:Java堆(Heap)、Java虚拟机栈(JVM Stacks)、本地方法栈(Native Method Stacks)、方法区(Method Area)、程序计数器(Register)。

Java内存管理(一)--内存分区

Java堆(Heap):Java内存中的最大一块,所有对象实例都放在Java堆中,而对于Java堆的垃圾回收器主要管理区域,当然也是最复杂的一块,通过-Xmx和-Xms来控制大小(第二篇将专门讲述Java垃圾回收工作),各线程共享。

Java虚拟机栈(JVM Stack):存放基本数据类型(int、short、boolean、byte、double、long、float、char)和对象引用,线程私有。

本地方法栈(Native Method Stack):和虚拟机栈(JVM Stack)相似,只不过它服务于本地方法(Native Method)同样线程私有。

方法区(Method Area):存放已被加载的类信息、常量、静态变量、即时编译器编译后的代码数据等。也就是我们时常说的永久带,各线程共享。

程序计数器Register):俗称:当前线程所执行的字节码的指示器,线程私有的。

直接内存(Direct Memory):并非java运行数据区中的部分,但是也会被Java程序用到。
原文地址:https://www.cnblogs.com/dengshiwei/p/4258451.html