JVM简单介绍

1. JVM 的工作流程

 

2.运行时的数据区

Run Data Area 分为两个大类,一个是所有线程共享的数据区,一个是线程私有的数据区。其中共享的数据区为方法区、堆区,私有的数据区为虚拟机栈、本地方法栈、程序计数器。

程序计数器:

每条线程都需要有一个程序计数器,计数器记录的是正在执行的指令地址,如果正在执行的是Native 方法,那么这个计数器的值为空。

Java 虚拟机栈:

Java 方法执行的内存模型,每个方法执行的时候,都会创建一个栈帧用于保存局部变量表,操作数栈,动态链接,方法出口信息等。一个方法的调用过程其实就是一个栈帧从VM栈入栈到出栈的过程。

Native 方法栈:

与VM栈发挥的作用极其相似,它执行的是Native方法服务。

Java堆:

此内存区域唯一的目的就是存放对象实例,几乎所有的对象都在这分配内存。

方法区:

方法区是各个内存所共享的内存空间,方法区中主要存放被JVM加载的类信息、常量、静态变量、即时编译后的代码等数据。

3.方法指令

invoke interface  调用接口方法

invoke virtual  调用对象的实例方法

invoke static 调用类/静态方法

invoke special 用于调用一些需要特殊处理的实例方法

4.类加载器 

分为BootstrapClassLoader(加载rt.jar 中的JDK文件)、ExtclassLoader、AppclassLoader(从classpath环境变量中加载某些应用相关).具体信息不再详述。

它们一共有三种工作原理,分别为委托机制、可见性机制、单一性机制。


5.垃圾回收机制

1.首先肯定是判断一个对象是否是垃圾(对象存活判断)

存活判断的方法:引用计数、可达性分析。

2.收集垃圾需要一个算法(垃圾收集算法)

标记-清除算法、复制算法、标记-整理算法、分代收集算法。

3.收集垃圾需要一个收集器(垃圾收集器)

CMS收集器、G1收集器。

4.回收垃圾需要一个策略(内存模型与回收策略)

Java 堆(Java Heap)是JVM所管理的内存中最大的一块,堆又是垃圾收集器管理的主要区域,Java 堆主要分为2个区域-年轻代与老年代,其中年轻代又分Eden区和Survivor区,其中 Survivor区又分 From和 To2个区。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值