• java分区以及运行时的数据区


    PC 程序计数器(ProgramCounter)
    内存空间小,字节码解释器工作时通过改变这个计数值可以选取下一条需要执行的字节码指令,分支、循环、跳转、异常处理和线程恢复等功能都需要依赖这个计数器完成。该内存区域是唯一一个java虚拟机规范没有规定任何OOM情况的区域。

    存放指令位置
    虚拟机的运行,类似于这样的循环:
    while( not end ) {
         取PC中的位置,找到对应位置的指令;
         执行该指令;
         PC ++;
    }

    栈JVM Stack

      1.Java使用基于栈的指令集,Hotspot中的Local Variable Table = JVM中的寄存器,虚拟机栈也就是我们平常所称的栈内存,它为java方法服务,每个方法在执行的时候都会创建一个栈帧(Frame) ,用于存储局部变量表、操作数栈、动态链接和方法出口等信息。

      2.虚拟机栈是线程私有的,它的生命周期与线程相同。

      3.局部变量表( Local Variable Table)里存储的是基本数据类型、returnAddress类型(指向一条字节码指令的地址)和对象引用,这个对象引用有可能是指向对象起始地址的一个指针,也有可能是代表对象的句柄或者与对象相关联的位置。局部变量所需的内存空间在编译器间确定.

      4.操作数栈的作用主要用来存储运算结果以及运算的操作数,它不同于局部变量表通过索引来访问,而是压栈和出栈的方式,return address a() -> b(),方法a调用了方法b, b方法的返回值放在什么地方。
      5.每个栈帧都包含一个指向运行时常量池中该栈帧所属方法的引用,持有这个引用是为了支持方法调用过程中的动态连接.动态链接(Dynamic Linking)就是将常量池中的符号引用在运行期转化为直接引用。 https://blog.csdn.net/qq_41813060/article/details/88379473

    堆Heap
    堆所有线程所共享的一块内存,在虚拟机启动时创建,几乎所有的对象实例都在这里创建,因此该区域经常发生垃圾回收操作。
    方法区Method Area

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

    运行时常量池Runtime Constant Pool
    用于存放静态编译产生的字面量和符号引用。该常量池具有动态性,也就是说常量并不一定是编译时确定,运行时生成的常量也会存在这个常量池中。
    本地方法栈Native Method Stack
    和虚拟机栈类似,只不过本地方法栈为Native方法服务。
    直接内存Direct Memory
    JVM可以直接访问的内核空间的内存 (OS 管理的内存)
    NIO , 提高效率,实现zero copy

    java数据区.png
     
    不积跬步,无以至千里
  • 相关阅读:
    nodejs express hi-cms
    写让别人能读懂的代码
    统计学和数据挖掘的关系
    假设检验
    相关性探索
    领域驱动设计分层类图
    未能加载文件或程序集 Ninject.Web.Common, Version=3.2.0.0
    论文阅读笔记
    《Computational Statistics with Matlab》硬译2
    C#抽象类和接口
  • 原文地址:https://www.cnblogs.com/farmersun/p/12398835.html
Copyright © 2020-2023  润新知