`
tjuximo
  • 浏览: 50595 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JVM内存分区

    博客分类:
  • JVM
 
阅读更多
总结一下JVM内存数据分区就是:
通常我们认为JVM运行时内存分为程序计数器、堆、栈三个部分。
程序计数器是线程独立的,大家可以这么想,在某一时刻、单处理器上,只能执行一条程序指令,所以某个线程的某个指令执行完之后才有可能把处理器资源释放出来处理其他线程的指令,程序计数器就是指向了某个线程下条待执行指令的地址,是基于线程的,所以是线程独立的。
栈,又分为虚拟机栈和本地方法栈,都是为方法执行服务的,只不过本地方法栈是为java底层调用的本地native方法服务的,在这里不做过多解释。我们一般而言的栈,就是指的虚拟机栈。虚拟机栈里存储的是一些局部变量、动态链接、方法出口等,这些数据存储在方法执行时创建的栈帧中。每个方法被调用到返回结束的这个过程,也是该方法生成的栈帧在虚拟机栈中入栈到出栈的过程。
虚拟机栈中存储的局部变量主要包括一些基本数据类型,如int/byte/long/char/float/boolean/short/double,和对象的reference,以及方法的returnAddress。由于方式执行时,每种数据结构的类型都是确定的,所以该方法需要在虚拟机栈帧中分配的空间大小也是确定的,方法执行期间不会改变大小。
栈也是线程独立的,它的生命周期和线程相同。
堆,又分为我们一般认为的Java堆和方法区。就像大家都知道的,Java堆存储的是Java中所有对象的实例和数组,所以它一般都是虚拟机运行时内存中最大的一块,也是垃圾回收的主要场所,所以也被称为GC堆(Garbage Collected Head)。Java堆中,还可分为老年代、新生代等,具体等到学习GC的时候讲。
Java堆是被所有线程共享的一块儿区域,随着JVM的启动而创建。
方法区主要存储虚拟机加载的类的信息、常量、静态变量等数据,所以一般也被大家称之为“永久代”,但也有垃圾回收的场景存在,一般是针对常量池和装载的类的回收。
方法区包含一块叫做运行时常量池的区域,它主要存放的是在编译期生成的各种字面量和符号引用,类加载时,这部分数据就被加载到常量池中。
运行时也可以把新的常量放入池中,应用比较多的是String.intern()方法。
直接内存不是虚拟机运行时管理的内存区域的一部分,也没有在Java虚拟机规范中定义,它是向本机直接申请的内存,具体应用是java NIO类,引入了一种基于管道channel与缓冲区buffer的IO方式,可以使用native函数库直接分配内存,通过存储在java 堆中的DirectByteBuffer对象作为这块区域内存的引用进行操作,避免了Java堆和Native堆来回复制数据。

那么,对于Object obj = new Object();是如何进行内存分配的呢?
如果代码出现在方法体中,Object obj这部分反映在Java栈的本地变量表中,作为一个reference类型数据出现,而new Object()这部分则反映到Java堆中,形成一块存储了Object类型实例的属性值得结构化内存,另外实例对应的类型信息,如class信息,父类、实现的接口、方法等类型数据存储在方法区中。
那么如何将栈中的reference访问到堆中的实例呢?
JVM规范中只规定reference是对对象的引用,而对采用何种方式进行定位,则没有具体规定,所以各个jvm实现也不一样,不过一般有两种方式,句柄式和指针式。
句柄式指的是,在Java堆中划分出一部分内存做句柄池,reference中存储的是要访问的对象的句柄地址,而在句柄中在存储对象的数据类型和访问地址。
指针式指的是,reference中直接存储对象的访问地址。
这两种方式各有优点,句柄式的好处是,reference中存储的是句柄地址,当发生垃圾收集的时候,只需要修改句柄中存储的对象访问地址,而不需要修改reference中的句柄地址,指针式的优点是,少了一层句柄寻址操作,方便快捷。

分享到:
评论

相关推荐

    JAVA内存分区与CC++内存分区的总结

    ### JAVA内存分区与C/C++内存分区的深度解析 #### JAVA内存分区 在JAVA中,JVM(Java虚拟机)的内存主要分为三个区域:堆(heap)、栈(stack)和方法区(method)。每个区域都有其特定的功能和管理机制。 1. **...

    JVM内存模型及分区 JVM内存模型及分区

    理解JVM内存模型对于优化Java程序性能至关重要,合理分配和管理内存能有效避免内存泄漏和性能瓶颈。例如,通过调整堆大小、设置合理的垃圾回收策略,可以优化应用的运行效率。此外,了解这些内存区域的工作原理也能...

    JVM性能调优-JVM内存整理及GC回收.pdf

    ### JVM性能调优——JVM内存管理与GC回收详解 #### 概览 在现代软件开发领域,Java凭借其强大的跨平台能力和丰富的生态系统成为企业级应用的首选语言之一。然而,随着应用程序复杂度的提高以及业务需求的变化,...

    ibm HeapAnalyzer JVM内存分析工具 ha457.jar下载

    为了充分利用IBM HeapAnalyzer,你需要了解JVM内存管理的基本概念,包括堆内存分区、垃圾收集器的工作机制以及内存泄漏的常见模式。同时,理解如何在Java应用中生成堆转储文件也是必不可少的,这通常可以通过JVM的...

    vmmap 观察jvm内存 监控jvm jvm线程

    `vmmap`工具是Mac OS X系统中一个强大的内存分析工具,它可以用来深入观察JVM内存的分配和使用情况。本文将详细讲解如何利用`vmmap`监控JVM,理解其核心概念,以及分析JVM线程。 首先,`vmmap`是Apple提供的命令行...

    JVM面试题.pdf

    十一、JVM 内存分区 JVM 内存主要分为以下几个区: * 方法区:用于存储类信息、常量池(静态常量和静态变量)、编译后的代码(字节码)等数据。 * 堆区:用于存储初始化的对象,成员变量(非静态变量),所有的...

    JAVA面试核心知识点整理283页-2020.pdf.zip

    jvm内存分区,gc算法,类加载机制。并发编程,并发编程各大容器,锁。框架spring mybatis原理,组件介绍。架构设计有设计模式,负载均衡。网络有协议,java 高并发io框架netty。数据结构包括堆栈,队列,链表,...

    JVM面试专题及答案(1).pdf

    JVM内存分区概述 综上所述,JVM内存模型涵盖了多个区域,每个区域都有其特定的功能和用途: - **堆区**:负责对象实例和数组的存储。 - **栈区**:用于存储线程局部变量、操作数栈等。 - **方法区**:存储类信息...

    JAVA面试核心知识点整理.rar

    jvm内存分区,gc算法,类加载机制。并发编程,并发编程各大容器,锁。框架spring mybatis原理,组件介绍。架构设计有设计模式,负载均衡。网络有协议,java 高并发io框架netty。数据结构包括堆栈,队列,链表,...

    JVM面试专题及答案.pdf

    11. **JVM内存分区作用**: - **方法区**:存储类元数据,包括常量池、类型信息等,执行GC主要是清理不再使用的常量和卸载类。 - **堆**:管理对象生命周期,进行对象分配和垃圾回收。 - **栈**:支持方法调用,...

    2021Java字节跳动面试题——面向字节_JVM(上).pdf

    JVM内存分区 JVM内存模型分为以下几个部分: - **程序计数器**:记录当前线程执行的行号。 - **Java虚拟机栈**:每个线程私有的,用于存储局部变量表、操作数栈、动态链接、方法出口等信息。 - **本地方法栈**:...

    Linux查看CPU和内存使用情况查看jvm内存使用情况.docx

    本篇文章将详细阐述如何使用`top`命令查看CPU使用情况,以及如何通过`free`命令检查内存使用情况,同时也会涉及查看JVM内存使用的方法。 1. **使用`top`命令查看CPU使用情况** `top`命令提供了一个实时的全屏界面...

    java虚拟机面试及答案.doc

    10. **JVM内存分区作用**: - 方法区:存储类信息和运行时常量池。 - 堆:存储对象实例和数组。 - 栈:处理方法调用,存储局部变量。 - 本地方法栈:支持JNI本地方法。 - 程序计数器:指示下一条要执行的字节码...

    java实现内存动态分配

    9. **内存分区的其他部分** 除了堆和栈,Java内存还包括方法区(存放类信息)、程序计数器(记录下一条指令的位置)和本地方法栈(为Java Native Interface提供服务)。这些区域在Java内存模型中同样占有重要地位,...

    JVM初探- 内存分配、GC原理与垃圾收集器

    JVM内存管理是Java虚拟机的核心机制之一,其主要包含对象的创建、内存分配、垃圾回收以及内存释放等过程。在JVM中,垃圾回收(GC)是自动管理内存的关键技术,其目的是回收不再使用的对象所占用的内存空间,以避免...

    Linux查看CPU和内存使用情况查看jvm内存使用情况.pdf

    `top`命令还支持多种内部命令,如`s`可调整屏幕刷新频率,`l`开关第一部分的第一行信息显示,`t`开关任务和CPU信息显示,`m`开关内存和交换分区信息显示,`N`、`P`、`M`分别按PID、CPU使用率和内存使用率排序进程,`...

    深入了解 JVM 虚拟机(超详细入门攻略)

    6. **JVM内存分区及作用** - **虚拟机栈**:为方法提供栈帧,存储局部变量、操作数栈、动态链接等。 - **本地方法栈**:为JNI调用的Native方法服务。 - **程序计数器**:记录当前线程执行的指令地址,用于多线程...

    java面试题

    9. **垃圾回收(GC)与内存管理**:理解Java内存模型(JVM内存分区),垃圾回收的工作原理,以及如何避免内存泄漏。 10. **设计模式**:至少需要了解并能应用单例、工厂、观察者、装饰器、代理等常见设计模式。 11...

    JVM大厂高频面试题,连这些都不知道,还敢说自己学过JVM?

    11. **JVM内存分区**: - 与上述1中的内存模型相同。 以上只是JVM知识体系的一部分,实际面试中可能还会涉及到内存泄漏、内存溢出、垃圾收集算法的细节、JVM调优策略等内容。理解并掌握这些知识点,将有助于在面试...

Global site tag (gtag.js) - Google Analytics