jvm基础-内存管理

好记性不如烂笔头。。。 工作这么多年还是要有点沉淀。。。

一 JVM内存范围


1、方法区(Method Area): 对于我们使用HotSpot虚拟机的程序员来说,方法区即平时我们所说的永久代(Perm Gen),它用于存储已被虚拟机加载的类信息,常量,以及静态变量等数据。虽然java虚拟机规范将方法区描述为堆的一个逻辑部分,但是它却有一个别名叫做非堆(No-Heap),目的是为了与堆进行区分,HotSpot虚拟机设计团队只是为了让方法区与java堆统一使用分代GC机制,才将它命名为永久代,与新生代(New Gen)老年代(Tenured Gen)使用同一套内存管理代码。运行时常量池(Runtime Constant Pool)属于方法区的一部分。

2、虚拟机栈(VM stack):虚拟机栈描述的是Java方法执行的内存模型,每个方法在执行同时会创建一个栈帧(Stack Frame),用于存储局部变量表(存放编译可知的基本数据类型,对象引用和returnAddress),操作数栈,动态链接,方法出口等信息。每个方法从调用到执行完成的过程,就对应着一个栈帧在虚拟机栈中的入栈与出栈的过程。

3、本地方法栈(Native stack):与虚拟机栈类似,区别就是虚拟机栈执行的是java方法(字节码),而本地方法栈执行的是Native方法。

4、堆(Heap):堆是虚拟机所管理的内存最大的一块,这块内存唯一的作用就是存放对象实例。几乎所有的对象实例以及数组都要在堆上分配内存。同时,我们平时所说的垃圾回收也大部分(堆外还有方法区与直接内存)集中在堆上,这是垃圾收集器管理的最主要的区域,后面会对堆这块进行详细介绍。

5、程序计数器:可以当作当前线程的执行的字节码的行号指示器,分支、循环、跳转、异常处理等基础功能都需要依赖程序计数器来指定到下一条要执行的字节码指令。

6、直接内存(Direct Memory):也就是狭义上的堆外内存,jdk1.4后引入了NIO包,为了提高I/O性能,该包下面提供了一个使用Native方法直接分配堆外内存的类-DirectByteBuffer,数据存储在直接内存,堆中的DirectByteBuffer对象作为该块内存的引用。该部分内存的分配不受java堆大小的限制,只会受本机总内存以及处理器寻址空间的限制。JDK5.0之后,代码中能直接操作本地内存的方式有2种:使用未公开的Unsafe和NIO包下ByteBuffer。


二 堆内存分配


1、对象优先在Eden分配:大多数情况下,对象在新生代Eden区中分配。当Eden区没有足够的空间进行分配时,虚拟机将会进行一次

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值