红包问答(已开奖):下面有关JVM内存,说法错误的是?


本期的红包问答题目:

下面有关JVM内存,说法错误的是?

A 程序计数器是一个比较小的内存区域,用于指示当前线程所执行的字节码执行到了第几行,是线程隔离的;
B 虚拟机栈描述的是Java方法执行的内存模型,用于存储局部变量,操作数栈,动态链接,方法出口等信息,是线程隔离的;
C 方法区用于存储JVM加载的类信息、常量、静态变量、以及编译器编译后的代码等数据,是线程隔离的;
D 原则上讲,所有的对象都在堆区上分配内存,是线程之间共享的

一、【规则】
本帖将采用最佳悬赏,评选出一位最佳回答者获得红包40元或者任意一门100元以内的课程(二选一)。

最佳回答者标准(可参考):

1、答案正确,且要有解析;
2、解析的字数不少于30;
3、解析为自己观点,不得抄袭;
4、解析要扣题,对问题的解析要有理有据,逻辑清晰。

二、【开奖日期】
下周一(3月11日)中午12点,届时会在本帖中公布最佳回答者。

加工作人员微信(微信号:julyedukefu06)领取红包。
......................分割线..............................................

恭喜昵称为:@qq用户313175 成为本期红包问答的最佳回答者。

红包问答.jpg


请加工作人员微信(微信号:julyedukefu06)领取红包。
已邀请:

463531

赞同来自:


答案:C

大多数 JVM 将内存区域划分为 Method Area(Non-Heap)(方法区) ,Heap(堆) , Program Counter Register(程序计数器) , VM Stack(虚拟机栈,也有翻译成JAVA 方法栈的),Native Method Stack ( 本地方法栈 ),其中Method Area 和 Heap 是线程共享的 ,VM Stack,Native Method Stack 和Program Counter Register 是非线程共享的。为什么分为 线程共享和非线程共享的呢?请继续往下看。

首先我们熟悉一下一个一般性的 Java 程序的工作过程。一个 Java 源程序文件,会被编译为字节码文件(以 class 为扩展名),每个java程序都需要运行在自己的JVM上,然后告知 JVM 程序的运行入口,再被 JVM 通过字节码解释器加载运行。那么程序开始运行后,都是如何涉及到各内存区域的呢?

概括地说来,JVM初始运行的时候都会分配好 Method Area(方法区) 和Heap(堆) ,而JVM 每遇到一个线程,就为其分配一个 Program Counter Register(程序计数器) , VM Stack(虚拟机栈)和Native Method Stack (本地方法栈), 当线程终止时,三者(虚拟机栈,本地方法栈和程序计数器)所占用的内存空间也会被释放掉。这也是为什么我把内存区域分为线程共享和非线程共享的原因,非线程共享的那三个区域的生命周期与所属线程相同,而线程共享的区域与JAVA程序运行的生命周期相同,所以这也是系统垃圾回收的场所只发生在线程共享的区域(实际上对大部分虚拟机来说知发生在Heap上)的原因。

要回复问题请先登录注册

返回顶部