java内存分区百科_JVM中的内存分区简介

1、JVM的内存区域划分:

大多数 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 )是非线程共享的。

2、为什么分为线程共享和非线程共享

首先我们熟悉一下一个一般性的 Java 程序的工作过程。一个 Java 源程序文件,会被编译为字节码文件(以 class 为扩展名),每个java程序都需要运行在自己的JVM                上,然 后告知 JVM 程序的运行入口,再被 JVM 通过字节码解释器加载运行。程序开始运行后就会涉及到JVM的这几个区:概括地说来,JVM初始运行的时候都会分配                     好 Method Area(方法区) 和Heap(堆) ,而JVM 每遇到一个线程,就为其分配一个 Program Counter Register(程序计数器) ,   VM Stack(虚拟机栈)和                             Native Method Stack  (本地方法栈),当线程终止时,三者(虚拟机栈,本地方法栈和程序计数器)所占用的内存空间也会被释放掉。这也是为什么我们            把内存区域         分为线程共享和非线程共享的原因,非线程共享的那三个区域的生命周期与所属线程相同,而线程共享的区域与JAVA程序运行的生命周期相同,所以这也是           系统垃圾回          收的场所只发生在线程共享的区域(实际上对大部分虚拟机来说知发生在Heap上)的原因。

3、下面给出JVM的内存模型图

3aa2189f8b31629c7bf824b2ce637dc8.png             方法区域存放了所加载的类的信息(名称、修饰符等)、类中的静态变量、类中定义为final类型的常量、类中的Field信息、类中的方法信息,当开发人员在程序中通过Class       对象中的getName、isInterface等方法来获取信息时,这些数据都来源于方法区域,同时方法区域也是全局共享的,在一定的条件下它也会被GC,当方法区域需要使用的内存          超过其允许的大小时,会抛出OutOfMemory的错误信息

a09bf1823b55e0e13cf83b002ecc3d74.png

可以参考如下的链接:

http://blog.csdn.net/ns_code/article/details/17565503

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值