文档章节

Java虚拟机jvm学习一:认识jvm的运行机制

silence88
 silence88
发布于 2017/02/26 17:45
字数 1211
阅读 34
收藏 1

一、认识jvm

JVM是Java Virtual Machine的简称。意为Java虚拟机

虚拟机是指通过软件模拟的具有完整硬件系统功能的、运行在一个完全隔离环境中的完整计算机系统

例如:VMWare、Visual Box、JVM

VMWare或者Visual Box都是使用软件模拟物理CPU的指令集

JVM使用软件模拟Java 字节码的指令集

JVM的编译:

javap -c的指令是将一段二进制代码转换为汇编的格式。

二、JVM运行机制

  • JVM启动流程

  • JVM基本结构

类加载器系统:classloader将class文件加载到jvm的内存空间中

本地方法栈:native标识的方法

pc寄存器:每个线程拥有一个pc寄存器,在线程创建时创建,指向下一条指令的地址。

方法区:主要保存的就是类的相关信息,类型的常量池,字段、方法信息,方法字节码。通常和永久区关联在一起。

java堆:

  • 1、和程序开发密切相关
  • 2、应用系统对象都保存在Java堆中
  • 3、所有线程共享Java堆
  • 4、对分代GC来说,堆也是分代的
  • 5、GC的主要工作区间

java栈:

  • 1、线程私有
  • 2、栈由一系列帧组成(因此Java栈也叫做帧栈)
  • 3、帧保存一个方法的局部变量、操作数栈、常量池指针
  • 4、每一次方法调用创建一个帧,并压栈

图说明:上方右边显示了100+98的过程,数据利用操作数栈临时保存。

Java栈 – 栈上分配

1、小对象(一般几十个bytes),在没有逃逸的情况下(栈是线程私有的,如果对于全局的变量就不能分配在栈上),可以直接分配在栈上

2、直接分配在栈上,可以自动回收(不需要GC清理),减轻GC压力

3、大对象或者逃逸对象无法栈上分配。

  • jvm内存模型

每一个线程都有一个工作内存和主存独立

工作内存存放主存中变量的值的拷贝。

1、当数据从主内存复制到工作存储时,必须出现两个动作:第一,由主内存执行的读(read)操作;第二,由工作内存执行的相应的load操作;当数据从工作内存拷贝到主内存时,也出现两个操作:第一个,由工作内存执行的存储(store)操作;第二,由主内存执行的相应的写(write)操作

2、每一个操作都是原子的,即执行期间不会被中断

3、对于普通变量,一个线程中更新的值,不能马上反应在其他变量中,如果需要在其他线程中立即可见,需要使用 volatile 关键字

volatile的说明:

public class Test extends Thread {

	private volatile boolean stop = true;

	public void stopme() {
		stop = false;
	}

	@Override
	public void run() {

		int i = 0;
		while (stop) {

			i++;
		}
		System.out.println("停止" + i);
	}

	public static void main(String[] args) throws InterruptedException {
		Test t = new Test();
		t.start();
		Thread.sleep(1000);
		t.stopme();
	}
}

上述代码的运行结果是:线程会结束。如果stop变量不使用volatile声明,则不会结束,因为线程永远适用的是拷贝到自己工作空间的值,而这个stop标识一直为true。

可见性:

一个线程修改了变量,其他线程可以立即知道

保证可见性的方法:

  • volatile
  • synchronized (unlock之前,写变量值回主存)
  • final(一旦初始化完成,其他线程就可见)

有序性:

在本线程操作内,操作都是有序的;(从结果看保证的结果是一致的)

而在线程外,操作都是无序的。产生这个的原因是指令重排或者主内存同步延时。

指令重排的基本原则

  • 1、程序顺序原则:一个线程内保证语义的串行性
  • 2、volatile规则:volatile变量的写,先发生于读
  • 3、锁规则:解锁(unlock)必然发生在随后的加锁(lock)前
  • 4、传递性:A先于B,B先于C 那么A必然先于C
  • 5、线程的start方法先于它的每一个动作
  • 6、线程的所有操作先于线程的终结(Thread.join())
  • 7、线程的中断(interrupt())先于被中断线程的代码
  • 8、对象的构造函数执行结束先于finalize()方法
  • 字节码运行的两种方式:

解释运行

  • 解释执行以解释方式运行字节码
  • 解释执行的意思是:读一句执行一句

编译运行(JIT)

  • 将字节码编译成机器码
  • 直接执行机器码
  • 运行时编译(也就是运行前先将字节码编译成机器码)
  • 编译后性能有数量级的提升

© 著作权归作者所有

共有 人打赏支持
silence88
粉丝 7
博文 71
码字总数 72855
作品 0
深圳
程序员
Java学习---Java简单认识

前言 小编在学习Java方面的基础知识,发现里面有很多是结合之前的语言的特点发展过来的,不同的地方是,Java有它自己的发展和特点。下面小编先简单地做一下总结,结合看过的1-2章的J2SE视频,...

m18633778874
04/01
0
0
[Java学习探讨]为什么学Java虚拟机的Java程序员更值钱?

[Java学习探讨]为什么学Java虚拟机的Java程序员更值钱? 曾经的我经常害怕处理与JVM相关的异常,对JVM的配置参数也一无所知,那时候我天真地认为,JVM的出现本身就是想让程序员屏蔽实现细节,...

原创小博客
07/19
0
0
JVM学习心得体会 (第一天)

Java虚拟机 Java虚拟机(Java Virtual Machine) 简称JVM Java虚拟机是一个想象中的机器,在实际的计算机上通过软件模拟来实现。Java虚拟机有自己想象中的硬件,如处理器、堆栈、寄存器等,还...

seng
2013/06/25
0
3
如果你想学习Java,那么就来看这篇文章

一、前言 我是从大二开始学习的Java,当时的目标是Java Web开发,当时并不想考研,所以当时的学习是以就业为主,现在我大三了,学习Java Web开发已经一年了,因为种种原因,决定要考研,所以...

Jivanmoon
08/27
0
0
1.3.2 java程序的运行机制和jvm

java语言比较特殊,由java语言编写的程序需要经过编译步骤,但这个编译步骤并不会生成特定平台的机器码,而是生成一种与平台无关的字节码(也就是*.class文件)。当然,这种字节码不是可执行...

Gooiem
2015/08/17
0
0

没有更多内容

加载失败,请刷新页面

加载更多

#mysql50# not Exist

data 目录有中文名称,可能是复制的"复件...."

少年不搬砖老大徒伤悲
21分钟前
1
0
在yii2中,让你action参数支持POST数据的小方法

我们先来看一段代码 class RaController extends Controller { public $enableCsrfValidation = false; public function actionSay($username = '',$city = ''){ echo "{$......

阿北2017
30分钟前
2
0
macOS 10.14 Mojave

在近日发布的 macOS 10.14 Mojave 操作系统中,有人发现它(在某些机型中)悄然禁用了先前的「次像素平滑渲染」选项,导致部分(尤其是使用非高分辨率显示器)用户觉得字体比先前的更细更难看...

火力全開
34分钟前
2
0
 实现分布式锁的正确姿势

实现分布式锁的正确姿势 原理分析 最近看到好多博主都在推分布式锁,实现方式很多,基于db、redis、zookeeper。zookeeper方式实现起来比较繁琐,这里我们就谈谈基于redis实现分布式锁的正确实...

DemonsI
38分钟前
2
0
微信小程序 、支付宝小程序、百度小程序和钉钉e应用的汇总

2018年9月25日 百度小程序开放企业申请 微信小程序:现在微信小游戏都热火朝天了,而且已经有了云开发,包括提供的能力、文档、社区等都相对完善,也有相关的变现方式; 支付宝小程序:https...

to_be_better
41分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部