美文网首页
chapter-2 jvm运行机制

chapter-2 jvm运行机制

作者: bryant_gbw | 来源:发表于2017-11-29 00:08 被阅读0次

本章知识点

1.JVM启动流程

2.JVM基本结构

3.内存模型

4.编译和解释运行的概念

JVM启动流程

   

JVM基本结构

        在Chapter - 1中介绍过,JVM是使用软件模拟java字节码的指令集,jvm有自己的类加载机制,将编译好的class文件加载到内存中,内存分成了多个不同的块(方法区,Java堆,Java栈,本地方法栈),每个块有自己的功能。

JVM基本结构

■ PC寄存器

    - 每个线程拥有一个PC寄存器

    -  在线程创建时 创建    

    -  指向下一条指令的地址

    -  执行本地方法时,PC的值为undefined

■ 方法区

     - 保存装载的类信息:类型的常量池,字段、方法信息,方法字节码。

    -  通常和永久区(Perm)关联在一起,永久区保存相对静止,少改变的信息。

■ Java堆

    - 和程序开发密切相关

    - 应用系统new出来对象都保存在Java堆中

    - 所有线程共享Java堆   

    - 对分代GC来说,堆也是分代的

    -  GC的主要工作区间

    - 数据结构,先进后出

■ Java栈

    -  线程私有

    -  栈由一系列帧组成(因此Java栈也叫做帧栈)

    -  帧保存一个方法的局部变量、操作数栈、常量池指针

    -  每一次方法调用创建一个帧,并压栈

    -  局部变量表 包含参数和局部变量

    -  函数调用组成帧栈

    -  操作数栈(Java没有寄存器,所有参数传递使用栈,在系统中称为操作数栈)

    - 栈上分配

        • 小对象(一般几十个bytes),在没有逃逸的情况下,可以直接分配在栈上,栈的内存空间比堆小很多

        • 直接分配在栈上,可以自动回收,减轻GC压力

        • 大对象或者逃逸对象无法栈上分配

    - 数据结构:先进后出

■ 栈,堆,方法区交互

■ 内存模型

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

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

■ 可见性

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

■ 保证可见性的方法:volatile;synchronized (unlock之前,写变量值回主存);final(一旦初始化完成,其他线程就可见)

■ 有序性

     - 在本线程内,操作都是有序的

    -  在线程外观察,操作都是无序的。(指令重排 或 主内存同步延时)

■ 指令重排

     - 线程内串行语义

        •写后读  a = 1;b = a;  写一个变量之后,再读这个位置。

        •写后写  a = 1;a = 2;  写一个变量之后,再写这个变量。

        •读后写  a = b;b = 1;  读一个变量之后,再写这个变量。

        •以上语句不可重排(在一个线程中,不管指令怎么变化,不改变执行结果,不改变语义,就可指令重排)

        •编译器不考虑多线程间的语义

        •可重排: a=1;b=2;

■ 指令重排 - 破坏线程间的有序性

■ 指令重排 - 保证有序性的方法

■ 指令重排的基本原则

     - 程序顺序原则:一个线程内保证语义的串行性

    - volatile规则:volatile变量的写,先发生于读 

    - 锁规则:解锁(unlock)必然发生在随后的加锁(lock)前 

    - 传递性:A先于B,B先于C 那么A必然先于C

    - 线程的start方法先于它的每一个动作 

    - 线程的所有操作先于线程的终结(Thread.join())

    - 线程的中断(interrupt())先于被中断线程的代码 

    - 对象的构造函数执行结束先于finalize()方法

■ 解释运行

     - 解释执行以解释方式运行字节码

    -  解释执行的意思是:读一句执行一句

■ 编译运行(JIT Just In Time及时编译)

     - 将字节码编译成机器码

    - 直接执行机器码

    - 运行时编译

    - 编译后性能有数量级的提升

    

    JVM 基本结构 - 内存模型

Java栈 - 也是局部变量表,包含参数和局部变量

        静态方法和实例方法(非静态方法):实例方法的第一个槽位是this(对象的引用),占一个槽位。

内存泄露

        Java中,new对象是在java堆中进行的,但是new出来的对象不用了,就需要手动的来删掉,删掉几十个可能比较简单,但是删掉成千上万的都比较麻烦了,当出现分配了内存,但是没有使用的情况,这个叫做内存泄露。

        堆上分配内存,每次都需要手动去清理,非常麻烦,而且会出现内存泄露的情况,栈上分配,函数调用完成就会自动清理,永远不会出现内存泄露的情况,栈上保存的是局部变量。

解释执行和编译执行

        编译执行比解释执行快10倍左右

相关文章

  • chapter-2 jvm运行机制

    本章知识点 1.JVM启动流程2.JVM基本结构3.内存模型4.编译和解释运行的概念 JVM启动流程 JVM基...

  • 深入JVM内核 目录

    深入JVM内核 目录 深入JVM内核1 初识JVM深入JVM内核2 JVM运行机制深入JVM内核3 常用JVM配置...

  • JVM学习笔记一

    JVM运行机制 JVM的启动过程 JVM的基本结构 JVM通过ClassLoader将class文件加载到内存中 ...

  • Java Review (Java开发环境)

    @ 高级语言运行机制编译型语言解释型语言 Java运行机制和JVM编写编译运行 JDK JREJDK、JRE与JV...

  • Java Review (Java开发环境)

    @ 高级语言运行机制编译型语言解释型语言 Java运行机制和JVM编写编译运行 JDK JREJDK、JRE与JV...

  • 多线程的锁升级原理

    什么是锁升级(锁膨胀)? JVM优化synchronized的运行机制,当JVM检测到不同的竞争状态时,就会根据需...

  • 2018-05-26 Java学习随笔4——有关Java语言、开

    Java的运行机制和JVM Java语言的运行机制大致如上图所示,Java源文件(源代码等.java文件)先经过J...

  • 1.JVM运行机制的整体脉络

    JVM系列 1.JVM运行机制的整体脉络2.JVM的分代模型及对象流动3.常见的垃圾回收器及算法4.ParNew和...

  • 4.ParNew和CMS的工作原理

    JVM系列 1.JVM运行机制的整体脉络2.JVM的分代模型及对象流动3.常见的垃圾回收器及算法4.ParNew和...

  • jvm运行机制

    当代码写的多了,有时容易产生疑惑,这段代码容不容易产生内存溢出呢?该怎么写才更为面向对象利于后期扩展,充分解耦。需...

网友评论

      本文标题:chapter-2 jvm运行机制

      本文链接:https://www.haomeiwen.com/subject/fwqybxtx.html