【转载】一些重要的java知识点:JVM内存模型和结构
今天看了一篇关于java一些重要知识点的文章觉得很不错,转载一下看看。 原地址:点击打开链接 作者:JerroLuo
1.1. JVM相关(包括了各个版本的特性)
对于刚刚接触Java的人来说,JVM相关的知识不一定需要理解很深,对此里面的概念有一些简单的了解即可。不过对于一个有着3年以上Java经验的资深开发者来说,不会JVM几乎是不可接受的。
JVM作为java运行的基础,很难相信对于JVM一点都不了解的人可以把java语言吃得很透。我在面试有超过3年Java经验的开发者的时候, JVM几乎就是一个必问的问题了。当然JVM不是唯一决定技术能力好坏的面试问题,但是可以佐证java开发能力的高低。
在JVM这个大类中,我认为需要掌握的知识有:
JVM内存模型和结构
GC原理,性能调优
调优:Thread Dump, 分析内存结构
class 二进制字节码结构, class loader 体系 , class加载过程 , 实例创建过程
方法执行过程:Java各个大版本更新提供的新特性(需要简单了解)
Ps:JVM内存模型和结构:
关于jvm的体系结构分为五个结构。方法区,堆,虚拟机栈,本地方法区,程序计数器PC。其中方法区和堆是所有线程共享的,每一个线程都有一个程序计数器。
程序计数器内存空间比较小,可以理解成程序存放的地址。
虚拟机栈,简称栈,成员方法会开辟一个空间可以叫做栈帧,栈帧里可以放方法里的局部变量,操作栈,返回地址等。
本地方法栈,和虚拟机栈类似,为虚拟机执行java方法(字节码)服务。这个为本地方法服务。
方法区,线程共享,用来存放已经被虚拟机加载的类信息,常量,静态变量等。
java堆,是被线程共享的一块区域。创建的对象和数组都保存在java堆内存中,也是垃圾收集器进行垃圾收集的重要内存区域。
运行时常量池,是方法区的一部分,用于保存编译器生成的各种字面量和富豪引用。
1. 程序计数器
1.1. 什么是程序计数器?
程序计数器是一块较小的内存空间,可以把它看作当前线程正在执行的字节码的行号指示器。也就是说,程序计数器里面记录的是当前线程正在执行的那一条字节码指令的地址。
注:但是,如果当前线程正在执行的是一个本地方法,那么此时程序计数器为空。1.2. 程序计数器的作用
程序计数器有两个作用:
- 字节码解释器通过改变程序计数器来依次读取指令,从而实现代码的流程控制,如:顺序执行、选择、循环、异常处理。
- 在多线程的情况下,程序计数器用于记录当前线程执行的位置,从而当线程被切换回来的时候能够知道该线程上次运行到哪儿了。
1.3. 程序计数器的特点
- 是一块较小的存储空间
- 线程私有。每条线程都有一个程序计数器。
- 是唯一一个不会出现OutOfMemoryError的内存区域。
- 生命周期随着线程的创建而创建,随着线程的结束而死亡。
2. Java虚拟机栈(JVM Stack)
2.1. 什么是Java虚拟机栈?
Java虚拟机栈是描述Java方法运行过程的内存模型。
Java虚拟机栈会为每一个即将运行的Java方法创建一块叫做“栈帧”的区域,这块区域用于存储该方法在运行过程中所需要的一些信息,这些信息包括:
- 局部变量表
存放基本数据类型变量、引用类型的变量、returnAddress类型的变量。- 操作数栈
- 动态链接
- 方法出口信息
- 等
当一个方法即将被运行时,Java虚拟机栈首先会在Java虚拟机栈中为该方法创建一块“栈帧”,栈帧中包含局部变量表、操作数栈、动态链接、方法出口信息等。当方法在运行过程中需要创建局部变量时,就将局部变量的值存入栈帧的局部变量表中。
当这个方法执行完毕后,这个方法所对应的栈帧将会出栈,并释放内存空间。注意:人们常说,Java的内存空间分为“栈”和“堆”,栈中存放局部变量,堆中存放对象。
这句话不完全正确!这里的“堆”可以这么理解,但这里的“栈”只代表了Java虚拟机栈中的局部变量表部分。真正的Java虚拟机栈是由一个个栈帧组成,而每个栈帧中都拥有:局部变量表、操作数栈、动态链接、方法出口信息。2.2. Java虚拟机栈的特点
- 局部变量表的创建是在方法被执行的时候,随着栈帧的创建而创建。而且,局部变量表的大小在编译时期就确定下来了,在创建的时候只需分配事先规定好的大小即可。此外,在方法运行的过程中局部变量表的大小是不会发生改变的。
- Java虚拟机栈会出现两种异常:StackOverFlowError和OutOfMemoryError。
a) StackOverFlowError:
若Java虚拟机栈的内存大小不允许动态扩展,那么当线程请求栈的深度超过当前Java虚拟机栈的最大深度的时候,就抛出StackOverFlowError异常。
b) OutOfMemoryError:
若Java虚拟机栈的内存大小允许动态扩展,且当线程请求栈时内存用完了,无法再动态扩展了,此时抛出OutOfMemoryError异常。- Java虚拟机栈也是线程私有的,每个线程都有各自的Java虚拟机栈,而且随着线程的创建而创建,随着线程的死亡而死亡。
注:StackOverFlowError和OutOfMemoryError的异同?
StackOverFlowError表示当前线程申请的栈超过了事先定好的栈的最大深度,但内存空间可能还有很多。
而OutOfMemoryError是指当线程申请栈时发现栈已经满了,而且内存也全都用光了。3. 本地方法栈
3.1. 什么是本地方法栈?
本地方法栈和Java虚拟机栈实现的功能类似,只不过本地方法区是本地方法运行的内存模型。
本地方法被执行的时候,在本地方法栈也会创建一个栈帧,用于存放该本地方法的局部变量表、操作数栈、动态链接、出口信息。
方法执行完毕后相应的栈帧也会出栈并释放内存空间。
也会抛出StackOverFlowError和OutOfMemoryError异常。
4. 堆
4.1. 什么是堆?
堆是用来存放对象的内存空间。
几乎所有的对象都存储在堆中。4.2. 堆的特点
- 线程共享
整个Java虚拟机只有一个堆,所有的线程都访问同一个堆。而程序计数器、Java虚拟机栈、本地方法栈都是一个线程对应一个的。- 在虚拟机启动时创建
- 垃圾回收的主要场所。
- 可以进一步细分为:新生代、老年代。
新生代又可被分为:Eden、From Survior、To Survior。
不同的区域存放具有不同生命周期的对象。这样可以根据不同的区域使用不同的垃圾回收算法,从而更具有针对性,从而更高效。- 堆的大小既可以固定也可以扩展,但主流的虚拟机堆的大小是可扩展的,因此当线程请求分配内存,但堆已满,且内存已满无法再扩展时,就抛出OutOfMemoryError。
5. 方法区
5.1. 什么是方法区?
Java虚拟机规范中定义方法区是堆的一个逻辑部分。
方法区中存放已经被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等。5.2. 方法区的特点
- 线程共享
方法区是堆的一个逻辑部分,因此和堆一样,都是线程共享的。整个虚拟机中只有一个方法区。- 永久代
方法区中的信息一般需要长期存在,而且它又是堆的逻辑分区,因此用堆的划分方法,我们把方法区称为老年代。- 内存回收效率低
方法区中的信息一般需要长期存在,回收一遍内存之后可能只有少量信息无效。
对方法区的内存回收的主要目标是:对常量池的回收 和 对类型的卸载。- Java虚拟机规范对方法区的要求比较宽松。
和堆一样,允许固定大小,也允许可扩展的大小,还允许不实现垃圾回收。5.3. 什么是运行时常量池?
方法区中存放三种数据:类信息、常量、静态变量、即时编译器编译后的代码。其中常量存储在运行时常量池中。
我们一般在一个类中通过public static final来声明一个常量。这个类被编译后便生成Class文件,这个类的所有信息都存储在这个class文件中。
当这个类被Java虚拟机加载后,class文件中的常量就存放在方法区的运行时常量池中。而且在运行期间,可以向常量池中添加新的常量。如:String类的intern()方法就能在运行期间向常量池中添加字符串常量。
当运行时常量池中的某些常量没有被对象引用,同时也没有被变量引用,那么就需要垃圾收集器回收。
6. 直接内存
直接内存是除Java虚拟机之外的内存,但也有可能被Java使用。
在NIO中引入了一种基于通道和缓冲的IO方式。它可以通过调用本地方法直接分配Java虚拟机之外的内存,然后通过一个存储在Java堆中的DirectByteBuffer对象直接操作该内存,而无需先将外面内存中的数据复制到堆中再操作,从而提升了数据操作的效率。
直接内存的大小不受Java虚拟机控制,但既然是内存,当内存不足时就会抛出OOM异常。
综上所述
- Java虚拟机的内存模型中一共有两个“栈”,分别是:Java虚拟机栈和本地方法栈。
两个“栈”的功能类似,都是方法运行过程的内存模型。并且两个“栈”内部构造相同,都是线程私有。
只不过Java虚拟机栈描述的是Java方法运行过程的内存模型,而本地方法栈是描述Java本地方法运行过程的内存模型。- Java虚拟机的内存模型中一共有两个“堆”,一个是原本的堆,一个是方法区。方法区本质上是属于堆的一个逻辑部分。堆中存放对象,方法区中存放类信息、常量、静态变量、即时编译器编译的代码。
- 堆是Java虚拟机中最大的一块内存区域,也是垃圾收集器主要的工作区域。
- 程序计数器、Java虚拟机栈、本地方法栈是线程私有的,即每个线程都拥有各自的程序计数器、Java虚拟机栈、本地方法区。并且他们的生命周期和所属的线程一样。
而堆、方法区是线程共享的,在Java虚拟机中只有一个堆、一个方法栈。并在JVM启动的时候就创建,JVM停止才销毁。暂时写这么多,往后的都看不太懂了。
原帖地址:点击打开链接
【转载】一些重要的java知识点:JVM内存模型和结构相关推荐
- 阿里P8大神讲解——Java,JVM内存模型
在Java程序界流行着一种默认的说法叫"黄金5年",也就是一个程序员从入职的时间开始算起,前五年的选择直接影响着整个职业生涯发展方向和薪资走向. 如何走好这5年很关键,如何彻底从一 ...
- 深入理解Java虚拟机--JVM内存模型
目录 一.运行时数据区域 1.程序计数器 2.Java 虚拟机栈 3.本地方法栈 4.Java 堆 5.方法区 6.运行时常量池 7.直接内存 二.OutOfMemoryError异常 1.Java堆 ...
- Java基础 —— JVM内存模型与垃圾回收
目录 一.概述 二.运行时数据区 方法区 运行时常量池 堆 栈 本地方法栈 程序计数器 三.对象访问 四.垃圾回收 如何定义垃圾 1.引用计数法 2.可达性分析 垃圾回收方法 1.Mark-Sweep ...
- 白话Java基础—JVM内存模型
白话Java基础系列-Java内存模型 本系列呢,主要将我理解的Java基础内容,以比较白话的方式,解释出来,希望能帮助大家快速的理解一些概念. 本文主要内容: 为什么要有Java内存模型?什么是Ja ...
- Java基础——JVM内存模型
2019独角兽企业重金招聘Python工程师标准>>> 是反射的方式 转载于:https://my.oschina.net/u/3746823/blog/1590736
- 深入理解JAVA虚拟机学习笔记(一)JVM内存模型
摘要: 上周末搬家后,家里的宽带一直没弄好,跟电信客服反映了N遍了终于约了个师傅明天早上来迁移宽带,可以结束一个多星期没网的痛苦日子了.这段时间也是各种忙,都一个星期没更新博客了,再不写之前那种状 ...
- JVM内存模型、Java内存模型 和 Java对象模型
一.JVM内存模型 1.JVM运行时数据区 二.Java内存模型(JMM) 1.JMM 三.Java对象模型 1.Java对象在JVM中的存储模型称之为Java对象模型. 四.总结 1.JVM内存 ...
- java查看jvm内存使用情况
java查看jvm内存使用情况 (2012-03-22 15:50:54) 标签: jvm 内存 虚拟机 分配 it java.lang.Runtime类提供了查看当前JVM内存的使用情况.每个jav ...
- 【Java杂货铺】JVM#Java高墙之内存模型
Java与C++之间有一堵由内存动态分配和垃圾回收技术所围成的"高墙",墙外的人想进去,墙外的人想出来.--<深入理解Java虚拟机> 前言 <深入理解Java虚 ...
- JVM#Java高墙之内存模型
前言 <深入理解Java虚拟机>,学习JVM的经典著作,几乎学习JAVA的小伙伴人手一本.当初买了,翻看了一部分,到了字节码那边彻底读不下去了,遂弃之.最近打算看Spring源码,反射.动 ...
最新文章
- Blazor带我重玩前端(五)
- C语言和设计模式(访问者模式)
- 1104File Space Bitmap Block损坏能修复吗
- oracle 地市 区县分组,oracle分组写法 - 挣扎在陌生城市ITMAN的个人空间 - OSCHINA - 中文开源技术交流社区...
- HBase编程api介绍(转)
- 北大中文核心期刊计算机类前30%名录
- 如何理解“方差越大信息量就越多”
- Jan Jürjens-基于模型的安全性系统-UMLChina讲座-音频和幻灯
- Windows实用工具推荐
- python使用EMQuantAPI查看股票各种指标
- 多线程爬取携程网酒店数据,星级数据和经纬度
- 计算机教师面试1分钟自我介绍视频,教师面试1分钟自我介绍
- dita最佳实践指南_艺术资产–最佳做法指南
- [CTF/网络安全]攻防世界unserialize3解题详析及php序列化反序列化实例讲解
- 解决淘宝旺旺无法运行的问题。。
- 如何快速批量转换图片格式?
- DotNetBar的groupPanel和buttonX背景色问题
- (附源码)计算机毕业设计SSM饮品外卖系统
- DS007-队列的原理-操作受限的线性表-queue的使用
- Web 页面怎么加货币符号和大写转换
热门文章
- 日志管理系统html,用户操作日志.html
- ubuntu mysql 升级_Ubuntu 升级mysql 之后的一些问题
- 阿里云云计算 19 块存储的使用
- 2012年之前Mac Book pro 安装新系统macOS 10.15 Catalina 制作U盘启动盘
- git项目合并(本地上传到已有的仓库)
- 123.买卖股票的最佳时机III
- Redraiment的走法
- 罗马仕php30重量,认真测评 篇三:罗马仕sence8P+两年使用报告
- 基于udp的协议netty课设题目_Netty UDP示例
- 现代通信原理3.2:线性系统的时域与频域特性