zoukankan      html  css  js  c++  java
  • [jvm] JVM体系结构

    一、jvm 运行时数据区域

    1. 程序计数器
    2. java虚拟机栈
    3. 本地方法栈
    4. java堆
    5. 方法区
    6. 运行时常量池
    7. 直接内存(非JVM区域)

    jvm内存分布

    二、深入探讨HotSpot虚拟机在Java堆中对象分配、布局和访问的全过程。

    1. 对象在java堆中的创建过程

    jvm对象初始化流程

    1. 对象在内存中的布局方式
      对象的内存布局
    2. 对象的访问定位
      目前主流的对象访问方式有两种:句柄直接指针
    • 句柄访问
      java堆中会划分出一块内存来作为句柄池,reference中存储的就是对象的句柄地址,而句柄中包含了对象的实例数据和各自具体的地址信息。
      在这里插入图片描述

    • 直接指针
      Java堆对象的布局中就必须考虑如何放置访问类型数据的相关信息,而reference中
      存储的直接就是对象地址。
      对象直接指针访问

      • 句柄访问和直接指针访问的区别:
    1. 使用句柄来访问的最大好处就是reference中存储的是稳定的句柄地址,在对象被移动(垃圾收集时移动对象是非常普遍的行为)时只会改变句柄中的实例数据指针,而reference本身不需要修改。
    2. 使用直接指针访问方式的最大好处就是速度更快,它节省了一次指针定位的时间开销,由于对象的访问在Java中非常频繁,因此这类开销积少成多后也是一项非常可观的执行成本。就本书讨论的主要虚拟机Sun HotSpot而言,它是使用第二种方式进行对象访问的,但从整个软件开发的范围来看,各种语言和框架使用句柄来访问的情况也十分常见。

    三、OutOfMemoryError 程序演示

    • 下回分解

    参考:深入理解JVM虚拟机第二章

  • 相关阅读:
    Java动态代理
    图解Python 【第七篇】:网络编程Socket
    我的FP感悟
    Scala微服务架构 三
    Scala微服务架构 二
    Scala微服务架构 一
    一篇入门 -- Scala
    基于DobboX的SOA服务集群搭建
    hadoop 异常及处理总结-01(小马哥-原创)
    使用Eclipse的几个必须掌握的快捷方式(能力工场小马哥收集)
  • 原文地址:https://www.cnblogs.com/ytuan996/p/10573614.html
Copyright © 2011-2022 走看看