JVM基本知识总结

大概两三个月之前阅读了《深入理解Java虚拟机》(周志明著),也为了加深印象,这里简单的做下总结,想完整点了解JVM知识的也可以阅读本书,书写的不错,相当通俗易懂。


第一部分 内存管理机制:

Java内存区域与内存溢出:

Java内存区域分为堆、栈(Java虚拟机栈和本地方法栈,不过对于hotspot来讲,是一致的)、方法区、程序计数器、直接内存区域(NIO的allocateByDireactMemory)等。借用@兰亭风雨 的图片一张

其中方法区用于加载类信息、常量、静态变量、即时编译器编译后的代码等数据的存储(运行时常量池也是方法区的一部分,Class文件的结构包括魔数、版本号、域、接口、方法等信息,常量池(Class文件常量池),用于存放编译器生成的各种字面量和符号引用)、堆区用于存放对象实例、栈的话通过压入或者弹出栈帧来控制程序,每个方法被执行的时候都会同时创建一个栈帧,一个栈帧需要分配多少内存,不会受到程序运行期变量数据的影响,而仅仅取决于具体的虚拟机实现。

内存溢出异常可以发生在栈、方法区、以及堆区(又被成为GC堆)。栈区如果发生溢出,可能是由于栈深度超出或者是线程栈的数量太多。方法区溢出原因可能是动态生成大量类或者是使用了String.intern()方法,堆区是可能由于new了大量的对象。

JVM垃圾回收:

要回收一个对象,首先要判断该对象是否无用,有两种方法:引用计数法和图的可达性分析(GC ROOTS:栈帧中的引用对象、方法区静态常量引用对象、本地方法引用对象)的方法。其中引用分四个类别:强引用、软引用、弱引用、影子引用(虚引用),引用强度依次减弱。JVM垃圾回有三种算法,复制、标记删除、标记整理,同时采用分代分代算法,基本上Young代采用复制,Old代采用标记删除或者整理。安全点(safepoint),JVM只有执行到安全点才会进行GC工作,安全点一般在方法调用、循环跳转、异常跳转等,有两种方法使得程序跑到安全点,分为抢占式和主动式。

Hotspot的垃圾收集器不算G1的话有6种,其中Serial(串行)、ParNew、Parallel作用于新生代,CMS、Serial Old、Parallel Old作用于老年代。具体的内容有空再补充上。基本上Web服务器采用CMS+ParNew的组合,降低响应时间。CMS的四次标记过程也是需要记住的,分别是初始标记、并发标记、重新标记、并发清楚。

时间: 2024-08-26 18:30:39

JVM基本知识总结的相关文章

JVM内存知识备忘

又是一篇备忘... 主要记录一些知识,进行一些资源的汇总. 先来群里liufor大大提供的两张图,清晰易懂: Dockerized Java https://www.youtube.com/watch?v=NQ5hTEp-GTM Java on Linux for devs and ops https://www.slideshare.net/aragozin/java-on-linux-for-devs-and-ops 常用配置&命令 常用命令 JVM启动用的命令行 jcmd process_

Java-100天知识进阶-JVM内存-知识铺(三)

知识铺: 致力于打造轻知识点,持续更新每次的知识点较少,阅读不累.不占太多时间,不停的来唤醒你记忆深处的知识点. Java内存模型(JMM) JVM内存模式是JVM的内存分区 Java内存模式是一种虚拟机规范 1.?Jvm内存按照运行时态及内存规范划分 Java内存区域 2.1** 线程安全 ** 2.1.1 程序计数器 2.1.2 虚拟机栈 2.1.3 本地方法 2.2 线程不安全 2.2.1 方法区 2.2.2 堆包含如下图 2.2.3 堆内存划分 总结: 程序计算器是唯一不会 OOM区 堆

JVM基础知识与配置

1 怎样设置JVM内存设置 本文向大家简介一下进行JVM内存设置几种方法.安装Java开发软件时.默认安装包括两个目录,一个JDK(Java开发工具箱).一个JRE(Java执行环境,内含JVM),当中JDK内另含一个JRE.假设仅仅是执行Java程序.则JRE已足够.而JDK则仅仅有开发者才用到.这里将为大家介绍设置JVM内存分配的几招. 浅谈JVM内存设置的几个妙招 一.设置JVM内存设置 1. 设置JVM内存的參数有四个: -Xmx    Java Heap最大值.默认值为物理内存的1/4

JVM 基础知识

转 http://m.blog.csdn.net/article/details?id=51244791JVM物理结构  1.Heap(堆):一个Java虚拟实例中只存在一个堆空间 2.MethodArea(方法区域):被装载的class的信息存储在Methodarea的内存中.当虚拟机装载某个类型时,它使用类装载器定位相应的class文件,然后读入这个class文件内容并把它传输到虚拟机中. 3.JavaStack(java的栈):虚拟机只会直接对Javastack执行两种操作:以帧为单位的压

关于JVM一些知识的粗浅认识

1. Java是如何跨平台的 Java将源代码编译成Class文件,是基于字节码的,字节码是以byte为单位存储的文件,和跨平台结合起来,它就是描述程序要运行的虚指令的集合,而这个虚指令与任何平台无关,Java虚拟机认识它,Java虚拟机将它翻译为对应的OS指令.Java虚拟机会为每个OS平台编写对应的JRE运行时环境,与OS动态链接,将这些虚指令编码翻译为对应操作系统的汇编指令信息,即可在对应的OS上调用执行了. 2. Java中"对象存放位置"小结 a. 当实例化一个对象时,如果对

【转】JVM 基础知识

几年前写过一篇关于JVM调优的文章,前段时间拿出来看了看,又添加了一些东西.突然发现,基础真的很重要.学习的过程是一个由表及里,再由里及表的过程,所谓的“温故而知新”.而真正能走完这个轮回的人,也就能称为大牛或专家了.这个过程可能来来回回,这就是所谓“螺旋上升”,而每一次轮回都有新的发现. 这回添加的东西主要集中在基础的一些问题上,还有一些这两年思考的问题.这些问题可能平时我们不会刻意去想,但是真正看清楚了,却发现还是大有裨益的,希望对大家都有帮助~ 一.基础概念 数据类型 Java虚拟机中,数

JVM 内存知识总结

本文主要参考内容: http://hllvm.group.iteye.com/group/wiki/3053-JVM http://my.oschina.net/xishuixixia/blog/133850 http://my.oschina.net/xishuixixia/blog/132395 http://www.cnblogs.com/gw811/archive/2012/10/18/2730117.html#undefined 1. JVM 内存模型: 程序计数器寄存器(The pc

mysql 第三十一篇文章~jvm的知识与优化

一 简介: 今天咱们聊聊 jvm内存调优二 基础理论:   1 jvm 堆(heap)基本概念:       1 对于大多数应用来说,Java堆(Java Heap)是Java虚拟机所管理的内存中最大的一块.Java堆是被所有线程共享的一块内存区域,在虚拟机启动时创建.此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存.       2 Java堆是垃圾收集器管理的主要区域,因此很多时候也被称做"GC堆".如果从内存回收的角度看,由于现在收集器基本都是采用的分代收

JVM基础知识及拓展

我们可以吧JVM的基本结构分为四块:类加载器.执行引擎.运行时数据区和本地接口.一般来说Java程序在JVM中的执行流程如下: ①.首先我们会利用javac命令将我们所编写的.java源代码文件变异成.class文件 : ②.类加载器将.class文件加载到运行时数据区: ③.利用执行引擎调用本地接口(本地方法库)执行程序: 这样我们的java程序也就跑起来了.下面我们通过上面所说的四块JVM结构来进行深入学习. 类加载器分类为三种: BootStrap Classloader:引导类加载器,负