• JVM运行时数据内存区和指令集(摘抄整理)


    指令集分类

    1. 基于寄存器的指令集
    2. 基于栈的指令集 Hotspot中的Local Variable Table = JVM中的寄存器

    Runtime Data Area

    PC 程序计数器:由于存在线程切换,线程需要有自己的程序计数器来记住指令执行到的位置【线程私有】

    存放指令位置

    虚拟机的运行,类似于这样的循环:

    while( not end ) {

    ​ 取PC中的位置,找到对应位置的指令;

    ​ 执行该指令;

    ​ PC ++;

    }

    JVM Stack【线程私有】

    1. Frame - 每个方法对应一个栈帧
      1. Local Variable Table:线程本地变量表
      2. Operand Stack 对于long的处理(store and load),多数虚拟机的实现都是原子的 jls 17.7,没必要加volatile :操作栈
      3. Dynamic Linking:一般是指向常量池 https://blog.csdn.net/qq_41813060/article/details/88379473 jvms 2.6.3
      4. return address a() -> b(),方法a调用了方法b, b方法的返回值放在什么地方

    Heap:堆,【线程共享】

    Method Area:方法区【线程共享】

    1. Perm Space 【永久代】(<1.8) 字符串常量位于PermSpace FGC不会清理 大小启动的时候指定,不能变
    2. Meta Space 【元数据】(>=1.8) 字符串常量位于堆 会触发FGC清理 不设定的话,最大就是物理内存

    Runtime Constant Pool:常量池,常见的是String常量池,实际上还存储着一些类的信息

    Native Method Stack:本地方法栈【线程私有】

    Direct Memory:直接内存

    JVM可以直接访问的内核空间的内存 (OS 管理的内存)

    NIO , 提高效率,实现zero copy

     

    常用指令(JVM的汇编指令)

    store:存

    load:取

    pop:弹出栈

    mul:乘法

    sub:减法

    invoke

    1. InvokeStatic:执行静态方法
    2. InvokeVirtual: 执行多态方法
    3. InvokeInterface:执行接口方法
    4. InovkeSpecial 可以直接定位,不需要多态的方法 private 方法 , 构造方法
    5. InvokeDynamic JVM最难的指令 lambda表达式或者反射或者其他动态语言scala kotlin,或者CGLib ASM,动态产生的class,会用到的指令
  • 相关阅读:
    甲骨文严查Java授权 、 openJDK 注意避坑
    evo工具评估slam算法生成的轨迹tum数据集
    领域驱动设计2编码规范
    领域驱动设计1整体代码设计
    XAMPP中phpmyadmin“无法连接:无效的设置”
    在ASP.NET Core Web API中使用SuperSocket.WebSocket.Server
    EFCore启用数据库连接池
    Kafka的Rebalance机制可能造成的影响及解决方案
    kafka如何保证数据的消息不丢失(最简洁)
    callable与future
  • 原文地址:https://www.cnblogs.com/gabin/p/13598671.html
Copyright © 2020-2023  润新知