JVM内存管理(面试)

本文论述的是JDK1.8.0之后的版本。

1.内存

2.新建对象过程
在这里插入图片描述

堆的构成:
在这里插入图片描述
JVM内存模型
在这里插入图片描述
A:程序计数器(program count register)
为线程私有,是一块比较小的内存空间,为当先线程所执行的字节码行号指示器。其指向吓一跳需要执行的字节码指令。该内存不会出现OutOfMemoryError。

B:本地方法栈
为线程私有,JVM需要使用到的Native方法服务。Sun HotSpot直接把本地方法栈和JVM栈合二为一。本地方法栈会抛出StackOverFlowError和OutOfMemoryError。Native Method就是Java调用非Java代码的接口。

C:Java虚拟机栈(Java vitual Machine Stack)
为线程私有,Java栈是Java方法执行的内存模型,栈中存放的是一个个的栈帧,每个栈帧对应一个被调用的方法,在栈帧中包括局部变量表、操作数栈、指向当前方法所属的类的运行常量池、方法返回地址和一些额外的附加信息。

D:方法区(Method )
为各个线程共享,用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据,别名:非堆,永久代。相对而言垃圾收集行为在这个区域比较少出现。当方法区无法满足内存分配需求时,将抛出OutOfMemoryError。

E:堆(Heap)
为线程共享区域,虚拟机所管理的内存中最大的一块。此内存区域的唯一目的是存放对象实例,几乎所有的对象实例都是在这里分配内存。
堆是垃圾收集器管理的主要区域,因为很多时候也被称为GC堆。堆可以细分为:新生代和老年代,新生代可以进一步分为Eden空间、From Survivor空间和To Survivor空间。如果在堆中没有内存完成实例分配,并且也无法再扩展时,将会抛出OutOfMemoryError异常。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值