关键词:
深入理解JVM
原文链接:https://www.cnblogs.com/dingyingsi/p/3760447.html
整理:CCSoft
虚拟机内存模型中定义的访问操作如下图所示:
图1. JVM虚拟机定义的访问操作
java中通过多线程机制使得多个任务同时执行处理,所有的线程共享JVM内存区域 主存(Main memory),而每个线程都有自己独立的工作内存,当线程与内存区域进行交互时,数据从主存拷贝到工作内存,进而由线程处理(操作码+操作数)。
JVM逻辑内存模型如下:
图2.JVM逻辑内存模型
接下来介绍每个的用途 :
1.程序计数器
当前线程所执行的字节码的行号指示器。通过改变计数器的值选取下一条指令。
分之,循环,跳转,异常处理,线程回复都依赖程序计数器完成。
多线程轮流切换分配处理器执行时间,在一个确定的时间,一个处理器(多核处理器的一个内核)只会执行一个线程的一条指令。
为了线程切换后能够恢复到正常的位置,每个线程都有独立的程序计数器,各条线程计数器互不影响,独立存储,我们称这类内存区域为“线程私有”的内存。
Java虚拟机规范:此内存区域是唯一一个没有规定任何OutofMemory情况的区域。
2.Java栈
与程序计数器一样,Java虚拟机栈(Java Vitual Machine Stacks)也是线程私有的,生命周期与线程相同。
该虚拟机栈描述的是Java方法执行的内存模型:每个方法执行的时候都会创建一个栈针(Stack Frame)用于存储局部变量表,操作栈,动态链接,方法出口等信息。
每一个方法被调用至执行完成的过程,就对应着一个栈针在虚拟机栈中从入栈到出栈的过程。
经常有把Java内存区域划分为堆内存Heap和栈内存Stack,这种说法是很粗糙的,实际上远比这复杂。不过上述划分说明了很多程序员关注这两块区域。其中栈内存Stack就是Java虚拟机栈。
局部变量表存放了编译期可知的基本数据类型,对象引用类型,returnAddress类型。
基本数据类型:boolean,byte,char,short,int ,float,long,double。其中long,double是占两个字节,其余都是占一个字节。
对象引用类型:对象的起始地址指针。
returnAddress类型:字节码指令地址。
在编译期时,局部变量表就已经确定了大小。
在方法运行期间,局部变量表的大小不能改变。
异常:
StackOverflowError:线程请求的栈深度大于虚拟机允许的深度。
OutofMemoryError:虚拟机动态扩展无法申请到足够的内存。
3.本地方法栈
本地方法栈与虚拟机栈所发挥的作用是非常相似的。区别是虚拟机栈为虚拟机执行Java方法服务,而本地方法栈是虚拟机使用到的Native方法服务。
在虚拟机规范中对本地方法栈中的方法使用的语言,使用的方式和数据结构没有强制的规定。
具体的虚拟机可以自由的实现。
在HotSpot虚拟机中,将Java虚拟机栈 和 本地方法栈 合并成了一个。
异常:
StackOverflowError
OutofMemoryError
扩展:Native方法
参考链接:https://blog.csdn.net/qiaoguaping9272/article/details/81805920
譬如:java.lang.Thread setPriority()方法是java实现的,该实现是调用类本地方法setPriority0()。这个方法是C语言实现的,是windows32 SetPriority() API。
4.Java堆
Java堆是Java虚拟机管理内存中最大的一块区域。
Java堆是被所有的线程共享的内存区域。在虚拟机启动的时候创建。用来存放所有对象的实例。
Java虚拟机规范描述:所有对象实例以及数组都要再Java堆上分配。
Java堆是垃圾收集器管理的主要区域。因此被称为GC堆(Garbage collected Heap).
根据Java虚拟机中的规定,Java堆可以处于物理上的不连续的内存空间中,但是逻辑连续即可。
异常:
OutofMemoryError:Java堆是可以扩展的,如果在堆中没有内存完成实例分配,或者堆中无法扩展的时候会抛出该异常。
5.方法区(Method Area)
方法区与Java堆一样,是各个线程共享的内存区域,用于存储已被虚拟机加载的类的信息、常量、静态变量、编译后的代码。
Java虚拟机规范中把方法区描述为堆中的一个部分,但是方法区的别名为Non-Heap(非堆),目的是为了和堆区分。
在HotSpot虚拟机中GC扩展了垃圾回收的区域,不仅有堆还有方法区。
Java虚拟机对方法区的限制很宽松,除了和堆一样不需要连续的空间和可选固定或者可扩展以外,还可以选择不实现垃圾回收。
该区域GC:主要针对常量池的回收(见5.1)和对类型的卸载。
这部分区域回首效率低,但是很有必要。在Sun公司的BUG列表中,HotSpot(低版本)未对该区域完全回收导致了非常严重的BUG。
异常
OutofMemoryError:当虚拟机方法区无法满足内存分配需求时,抛出该异常。
5.1运行时常量池(Runtime Constant Pool)
为啥标注是5.1 因为运行时常量池是方法区的一部分,用来存放编译器生成的各种字面量 和 符号引用。
对于运行时常量池,java虚拟机没有任何细节的要求,除了保存Class文件中的符号引用外,还会把编译出来的直接引用也存储到运行时的常量池中。
在Java语言中,常量可以在编译时期产生(预置在Class文件中放入常量池)。也可以在运行期间将新的常量放入常量池中。String类的intern()方法。
异常:
OutofMemoryError,运行时常量池属于方法区的一部分,会受到该方法区内存大小的限制,常量池无法申请到内存时报该异常。
[译]深入理解jvm
http://www.cnblogs.com/enjiex/p/5079338.html 深入理解JVM原文链接:http://www.cubrid.org/blog/dev-platform/understanding-jvm-internals每个使用Java的开发者都知道Java字节码是在JRE中运行(JRE:Java运行时环境)。JVM则是JRE中的核心组成部分,承担分析和执... 查看详情
深入理解jvm
2.jvm性能调优都做了什么3.介绍JVM中7个区域,然后把每个区域可能造成内存的溢出的情况说明内存溢出和合理分配:http://blog.csdn.net/ye1992/article/details/9344807http://flychao88.iteye.com/blog/2226205http://www.itzhai.com/jvm-note-automatic-memory-mana 查看详情
深入理解jvm之jvm内存区域与内存分配
...e=tuicool&utm_medium=referral 看了此博客后,发现应该去深入学习下jvm 查看详情
深入理解jvm的内存区域
深入理解运行时数据区代码示例:1.JVM 向操作系统申请内存: JVM 第一步就是通过配置参数或者默认配置参数向操作系统申请内存空间,根据内存大小找到具体的内存分配表,然后把内存段的起始地址和终止地址分配... 查看详情
jvm(32),理解升级----(挺不错的)图解深入理解jvm之jvm内存区域与内存分配
...于JVM内存区域的文章,由网上一些有关这方面的文章和《深入理解Java虚拟机》整理而来,所以会有些类同的地方,也不能保证我自己写的比其他网上的和书本上的要好,也不可能会这样。写博客的目的是为了个人对这方面自己... 查看详情
《深入理解jvm——如何优化javagc「译」》
JVM深入理解JVM(4)——如何优化JavaGC「译」 PostedbyCrowonAugust21,2017本文翻译自SangminLee发表在Cubrid上的”BecomeaJavaGCExpert”系列文章的第三篇《HowtoTuneJavaGarbageCollection》,本文的作者是韩国人,写在JDK1.8发布之前,虽然... 查看详情
深入理解jvm-垃圾回收器
看完《深入理解JVM》,结合网上资料后根据跟人理解整理出的简洁版,主要关注是什么,怎么做到的,特点等,没有进入深入剖析,旨在快速了解,具体应用时个人再根据具体点去进行深入。欢迎留言讨论!是什么?垃圾回收器... 查看详情
深入理解jvm之jvm内存区域与内存分配
深入理解JVM之JVM内存区域与内存分配 在学习jvm的内存分配的时候,看到的这篇博客,该博客对jvm的内存分配总结的很好,同时也利用jvm的内存模型解释了java程序中有关参数传递的问题。 博客出处: http://www.cnblogs.com/... 查看详情
深入理解jvm——jvm内存模型
...地方法栈 4.堆 5.方法区。下面对这五个区域展开深入的介绍。 1.程序计数器1.1.什么是程序计数器?程序计数器是一块较小的内存空间,可以把它看作当前线程正在执行的字节码的行号指示器。 查看详情
深入理解jvm
深入理解JVM1 Java技术与Java虚拟机 说起Java,人们首先想到的是Java编程语言,然而事实上,Java是一种技术,它由四方面组成:Java编程语言、Java类文件格式、Java虚拟机和Java应用程序接口(JavaAPI)。它们的关系如下图所示:图... 查看详情
hashmap工作原理深入理解jvm正则
HashMap工作原理:http://www.importnew.com/7099.html;http://blog.csdn.net/ghsau/article/details/16843543;http://blog.csdn.net/ghsau/article/details/16890151。 深入理解JVM:http://www.importnew.com/17770.html 查看详情
《深入理解jvm——gc算法与内存分配策略》
JVM深入理解JVM(2)——GC算法与内存分配策略 PostedbyCrowonAugust10,2017说起垃圾收集(GarbageCollection,GC),想必大家都不陌生,它是JVM实现里非常重要的一环,JVM成熟的内存动态分配与回收技术使Java(当然还有其他运行... 查看详情
《深入理解jvm——类加载器》
JVM深入理解JVM(6)——类加载器 PostedbyCrowonAugust21,2017虚拟机设计团队把类加载阶段中的“通过一个类的全限定名来获取描述此类的二进制字节流(即字节码)”这个动作放到Java虚拟机外部去实现,以便让应用程序自... 查看详情
深入理解jvm
一、JVM简介 JVM是JavaVirtualMachine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。 Java语言的一个非常重要的特点就是跨平台... 查看详情
深入理解jvm之jvm内存区域与内存分配
...e=tuicool&utm_medium=referral 看了此博客后,发现应该去深入学习下jvm的内 查看详情
深入理解jvm
概述JVMJVM简介:JVM全称是Java VirtualMachine,Java虚拟机,也就是在计算机上再虚拟一个计算机,这和我们使用 VMWare不一样,那个虚拟的东西你是可以看到的,这个JVM你是看不到的,它存在内存中。我们知道计算机的基本构... 查看详情
《深入理解jvm——gc算法与内存分配策略》(代码片段)
JVM深入理解JVM(2)——GC算法与内存分配策略 PostedbyCrowonAugust10,2017说起垃圾收集(GarbageCollection,GC),想必大家都不陌生,它是JVM实现里非常重要的一环,JVM成熟的内存动态分配与回收技术使Java(当然还有其他运行... 查看详情
深入理解jvm一配置参数
一、JVM配置参数分为三类参数:1、跟踪参数2、堆分配参数3、栈分配参数这三类参数分别用于跟踪监控JVM状态,分配堆内存以及分配栈内存。二、跟踪参数跟踪参数用于跟踪监控JVM,往往被开发人员用于JVM调优以及故障排查。1... 查看详情