1.执行引擎

  • 所有Java虚拟机的执行引擎都是一致的: 输入的是字节码文件,处理过程就是解析过程,最后输出执行结果。
  • 在整个过程不同的数据在不同的结构中进行处理。

2.栈帧

  • jvm进行方法调用和方法执行的数据结构,是虚拟机栈的元素。
  • (图片来自网络)
  1. 栈帧包括:局部变量表、操作数栈、动态链接、方法返回地址等
  2. 编译期就确定了需要多大的局部变量表,多深的操作数栈,这些信息全在字节码中。
  3. 只有位于栈顶的栈帧才有效,称为当前栈帧,所对应的方法就是当前正在执行的方法。

2.1 局部变量表

  • 存放方法参数和方法内部定义的局部变量。
  1. 容量以变量槽slot为单位,slot内存大小随着需求而变化并且不固定。
  2. 方法执行时jvm使用局部变量表完成参数值到参数列表的传递过程。
  3. slot可以被其他变量复用。
  4. 局部变量不存在准备阶段,所以不会赋予系统初始值,如果不初始化那么他就不能使用。
  5. jvm通过索引定位的方式定位slot,从0到最大slot数量。0位索引slot是用来存放方法所属对象实例的引用(this),之后按参数列表分配slot,再后按照局部变量顺序分配slot。

2.2操作数栈

  • 方法刚刚开始执行时为空,在执行过程中会有各种字节码指令往操作数栈中写入和提取内容,也就是入栈/出栈操作。
  • 概念上两个栈帧相互独立,但大多数虚拟机会存在一些优化,让下面栈帧的操作数栈部分区域和上面栈帧的部分局部变量表重合,成为共享区域。

2.3动态链接

  • 保存 指向运行时常量池中 该栈帧所属方法的 引用。
  • 作用就是 运行期间将符号引用转化为直接引用。

2.4方法返回地址

  • 保留一些退出方法时 上层方法执行状态 的信息

3.方法的调用,动态绑定过程。

  • 编译过程不包括传统的连接,class文件中只是存符号引用,而不是直接引用。
  • 方法调用就是确定该方法是哪个类的哪个方法换个说法就是绑定,这不同于方法执行。
  1. 解析

    • 符号引用转化为直接引用,因为编译器并不知道分配内存后某个变量具体内存位置,所以编译时使用一个符号代替,分配内存后该变量所在的内存位置就等于这个符号,解析阶段找到这个符号对应的内存位置然后指向她,这就是符号引用转化为直接引用。
    1. 类加载的解析阶段会把 部分符号引用转化为直接引用,但这种解析的前提条件就是:方法在程序执行之前就有一个就可以确定的版本,并且在运行期间不可变。
    2. 编译期可知运行期不可变这种方法有static和private方法,想想也是,这两种方法只有定义他们的类才能调用,他们一出生就确定了唯一的主人。他们不可能被继承或者重写其他版本。
    3. 实例构造器,父类方法这2中也能确定唯一的版本,所以这些方法也是在类加载阶段解析为直接引用。
    4. 静态方法,私有方法,实例构造器,父类方法这些方法可确定唯一版本所以统称为 非虚方法,final方法也是非虚方法。
  2. 分派调用

    • 分派调用就是多态特征的体现,在重载重写的方法中正确确定版本。
    1. 静态类型和动态类型

      • Human man =  new  Man();
      • Human 就是变量man 的静态类型, Man 就是man 的实际类型。
      • 静态类型在编译期可知,动态类型在运行期才能确定
    2. 静态分派:根据参数的静态类型确定该方法使用的版本
      • 方法被重载了好几个版本,确定要使用哪一个版本就是通过当前调用方法传入参数的静态类型确定版本。
      • 静态分派会找到一个和参数静态类型最适合的版本,如 int 类型传入多个没有int的重载版本中还会找到float版本。
      • 静态分派在编译期确定调用哪一个版本,并把符号引用记录下来。
      • 注意静态分派只确定了方法的版本,如果一个类没有继承其他类当前方法也不是覆写了父类方法,那么他就只有这一个版本可用,如果重写了父类方法,那么就由动态分派来确定使用哪个重写方法。
    3. 动态分派:运行期间根据调用方法的对象的实际类型确定使用哪个类的方法,也就是确定使用哪个重写方法。编译期间无法确定实际类型
      1. 找到调用当前方法的对象的实际类型
      2. 在实际类型中由静态分派确定方法版本。
      3. 如果找到对应版本则检查访问权限如果通过则返回此方法的引用。
      4. 如果找不到则从下往上在父类中找,如果找不到则抛出异常。
    4. 单分派多分派
      • 方法的接收者和参数统称为综量
      • 静态分派是根据方法参数确定的,方法参数可以有多个所以是多个宗量,属于多分派。
      • 动态分派是根据一个实际类型确定的所以属于单宗量,所以是单分派。
      • Java 目前是一门静态多分派,动态单分派的语言。
    5. 静态分派和动态分派的区别
      1. 静态分派通过参数类型查找重载版本,并且是参数的静态类型。
      2. 动态分派通过调用方法的对象查找重写版本,并且是对象的实际类型。

4. 字段的调用和方法的调用不同

  1.  当一个引用变量它的编译时的类型和运行是的类型不一样时:

    • 通过引用调用字段则调用的是 编译时类型(静态类型 )对象的字段,也就是父类的字段。
    • 通过引用调用方法则是通过动态分派调用实际类型的方法,如果没有就去父类中查找。

JVM字节码执行引擎和动态绑定原理的更多相关文章

  1. JVM总结(五):JVM字节码执行引擎

    JVM字节码执行引擎 运行时栈帧结构 局部变量表 操作数栈 动态连接 方法返回地址 附加信息 方法调用 解析 分派 –“重载”和“重写”的实现 静态分派 动态分派 单分派和多分派 JVM动态分派的实现 ...

  2. 一夜搞懂 | JVM 字节码执行引擎

    前言 本文已经收录到我的 Github 个人博客,欢迎大佬们光临寒舍: 我的 GIthub 博客 学习导图 一.为什么要学习字节码执行引擎? 代码编译的结果从本地机器码转变为字节码,是存储格式发展的一 ...

  3. 深入理解JVM—字节码执行引擎

    原文地址:http://yhjhappy234.blog.163.com/blog/static/3163283220122204355694/ 前面我们不止一次的提到,Java是一种跨平台的语言,为 ...

  4. JVM字节码执行引擎

    一.概述 在不同的虚拟机实现里面,执行引擎在执行Java代码的时候可能会有解释执行(通过解释器执行)和编译器执行(通过即时编译器产生本地代码执行)两种选择,所有的Java虚拟机的执行引擎都是一致的:输 ...

  5. 图解JVM字节码执行引擎之栈帧结构

    一.执行引擎      “虚拟机”的概念是相对于“物理机”而言的,这两种“机器”都有执行代码的能力.物理机的执行引擎是直接建立在硬件处理器.物理寄存器.指令集和操作系统层面的:而“虚拟机”的执行引擎是 ...

  6. 深入理解JVM虚拟机5:虚拟机字节码执行引擎

    虚拟机字节码执行引擎   转自https://juejin.im/post/5abc97ff518825556a727e66 所谓的「虚拟机字节码执行引擎」其实就是 JVM 根据 Class 文件中给 ...

  7. JVM学习笔记:字节码执行引擎

    JVM学习笔记:字节码执行引擎 移步大神贴:http://rednaxelafx.iteye.com/blog/492667  

  8. JVM基础结构与字节码执行引擎

    JVM基础结构 JVM内部结构如下:栈.堆. 栈 JVM中的栈主要是指线程里面的栈,里面有方法栈.native方法栈.PC寄存器等等:每个方法栈是由栈帧组成的:每个栈帧是由局部变量表.操作数栈等组成. ...

  9. 深入理解Java虚拟机(类文件结构+类加载机制+字节码执行引擎)

    目录 1.类文件结构 1.1 Class类文件结构 1.2 魔数与Class文件的版本 1.3 常量池 1.4 访问标志 1.5 类索引.父索引与接口索引集合 1.6 字段表集合 1.7 方法集合 1 ...

随机推荐

  1. java使用POI操作XWPFDocument中的XWPFParagraph(段落)对象的属性略解

    我用的是office word 2016版 创建文本对象 XWPFDocument docxDocument = new XWPFDocument(); 创建段落对象 XWPFParagraph pa ...

  2. ACE_DEBUG介绍及日志输出

    转载于:http://blog.csdn.net/zzjxiaozi/article/details/6642925 ACE_DEBUG  常规的一些输出消息   ACE_ERROR  会提供程序出错 ...

  3. 牛客326B 背单词

    传送门:https://ac.nowcoder.com/acm/contest/326/B 题意:给你一个n,你需有找有多少个长度从1~n 的单词,满足最长连续元音少于A个并且最长连续辅音长度少于B. ...

  4. ubuntu14安装tensorflow并测试

    1.ubuntu版本的选择:看了很多博文,建议使用ubuntu14,稳定兼容性好. 2.tensorflow的安装: http://wiki.jikexueyuan.com/project/tenso ...

  5. 9.python爬虫--pyspider

    pyspider简介 PySpider:一个国人编写的强大的网络爬虫系统并带有强大的WebUI.采用Python语言编写,分布式架构,支持多种数据库后端,强大的WebUI支持脚本编辑器,任务监视器,项 ...

  6. vijos 1037 背包+标记

    描述 2001年9月11日,一场突发的灾难将纽约世界贸易中心大厦夷为平地,Mr. F曾亲眼目睹了这次灾难.为了纪念“9?11”事件,Mr. F决定自己用水晶来搭建一座双塔. Mr. F有N块水晶,每块 ...

  7. 「模板」 01 Trie实现平衡树功能

    不想多说什么了.费空间,也不算太快,唯一的好处就是好写吧. #include <cstdio> #include <cstring> const int MAXN=100010 ...

  8. 【BZOJ4903】【CTSC2017】吉夫特 [DP]

    吉夫特 Time Limit: 15 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description Input 第一行一个整数n. 接下 ...

  9. ajax post请求json数据在spring-controller解析

    1.前端post请求数据: userInfo=[{"id":"5","uname":"小李","phone&q ...

  10. Warning: File upload error - unable to create a temporary file in Unknown on line 0

    upload_tmp_dir 临时文件夹问题 上传文件提示 Warning: File upload error - unable to create a temporary file in Unkn ...