首页 > 系统相关 >JVM内存区域

JVM内存区域

时间:2024-06-21 09:02:33浏览次数:22  
标签:Java 虚拟机 区域 线程 内存 JVM 方法 Native

目录

一、程序计数器(线程私有)

二、虚拟机栈(线程私有)

三、堆(Heap-线程共享)-运行时数据区

四、方法区/永久代(线程共享)

五、本地方法区(线程私有)


invalid image(图片无法加载)


JVM 内存区域主要分为线程私有区域【程序计数器、虚拟机栈、本地方法区】、线程共享区 域【JAVA 堆、方法区】、直接内存。
线程私有数据区域生命周期与线程相同, 依赖用户线程的启动/结束 而 创建/销毁(在 Hotspot VM 内, 每个线程都与操作系统的本地线程直接映射, 因此这部分内存区域的存/否跟随本地线程的 生/死对应)。

线程共享区域随虚拟机的启动/关闭而创建/销毁。
直接内存并不是 JVM 运行时数据区的一部分, 但也会被频繁的使用: 在 JDK 1.4 引入的 NIO 提 供了基于 Channel 与 Buffer 的 IO 方式, 它可以使用 Native 函数库直接分配堆外内存, 然后使用 DirectByteBuffer 对象作为这块内存的引用进行操作(详见:Java I/O 扩展), 这样就避免了在 Java 堆和 Native 堆中来回复制数据, 因此在一些场景中可以显著提高性能。

invalid image(图片无法加载)

一、程序计数器(线程私有)

一块较小的内存空间, 是当前线程所执行的字节码的行号指示器,每条线程都要有一个独立的 程序计数器,这类内存也称为“线程私有”的内存。
正在执行 java 方法的话,计数器记录的是虚拟机字节码指令的地址(当前指令的地址)。如 果还是 Native 方法, 则为空。
这个内存区域是唯一一个在虚拟机中没有规定任何 OutOfMemoryError 情况的区域。

二、虚拟机栈(线程私有)

是描述java 方法执行的内存模型,每个方法在执行的同时都会创建一个栈帧(Stack Frame) 用于存储局部变量表、操作数栈、动态链接、方法出口等信息。每一个方法从调用直至执行完成 的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。
栈帧(Frame)是用来存储数据和部分过程结果的数据结构, 同时也被用来处理动态链接
(Dynamic Linking)、 方法返回值和异常分派(Dispatch Exception)。栈帧随着方法调用而创
建,随着方法结束而销毁——无论方法是正常完成还是异常完成(抛出了在方法内未被捕获的异 常)都算作方法结束。

invalid image(图片无法加载)

三、堆(Heap-线程共享)-运行时数据区

是被线程共享的一块内存区域, 创建的对象和数组都保存在 Java 堆内存中,也是垃圾收集器进行 垃圾收集的最重要的内存区域。 由于现代 VM 采用分代收集算法, 因此 Java 堆从 GC 的角度还可以 细分为: 新生代(Eden 区、From Survivor 区和 To Survivor 区)和老年代。

四、方法区/永久代(线程共享)

即我们常说的永久代(Permanent Generation), 用于存储被 JVM 加载的类信息、常量、静 态变量、即时编译器编译后的代码等数据. HotSpot VM 把 GC 分代收集扩展至方法区, 即使用 Java 堆的永久代来实现方法区, 这样 HotSpot 的垃圾收集器就可以像管理 Java 堆一样管理这部分内存, 而不必为方法区开发专门的内存管理器(永久带的内存回收的主要目标是针对常量池的回收和类型 的卸载, 因此收益一般很小)。

运行时常量池(Runtime Constant Pool)是方法区的一部分。Class 文件中除了有类的
版 本、字段、方法、接口等描述等信息外, 还有一项信息是常量池
(Constant Pool Table) ,用于存放编译期生成的各种字面量和符号引用, 这部分内容将在类加 载后存放到方法区的运行时常量池中。 Java 虚拟机对 Class 文件的每一部分(自然也包括常量
池)的格式都有严格的规定,每一个字节用于存储哪种数据都必须符合规范上的要求, 这样才会 被虚拟机认可、装载和执行。

线程共享区域随虚拟机的启动/关闭而创建/销毁。
直接内存并不是 JVM 运行时数据区的一部分, 但也会被频繁的使用: 在 JDK 1.4 引入的 NIO 提 供了基于 Channel 与 Buffer 的 IO 方式, 它可以使用 Native 函数库直接分配堆外内存, 然后使用 DirectByteBuffer 对象作为这块内存的引用进行操作(详见:Java I/O 扩展), 这样就避免了在 Java 堆和 Native 堆中来回复制数据, 因此在一些场景中可以显著提高性能。

invalid image(图片无法加载)

五、本地方法区(线程私有)

本地方法区和 Java Stack 作用类似, 区别是虚拟机栈为执行 Java 方法服务, 而本地方法栈则为 Native 方法服务, 如果一个 VM 实现使用 C-linkage 模型来支持 Native 调用, 那么该栈将会是一个 C 栈,但 HotSpot VM 直接就把本地方法栈和虚拟机栈合二为一。

标签:Java,虚拟机,区域,线程,内存,JVM,方法,Native
From: https://blog.csdn.net/w12345ll/article/details/139848211

相关文章

  • JVM:不同垃圾收集算法和垃圾收集器 优缺点总结
     如何判断对象是否为垃圾:引用计数法:对象是否被引用,无法解决对象循环引用导致的问题可达性分析:也叫根搜索法 垃圾收集算法1、标记-清除(Mark-Sweep)示意图深蓝色:有引用深灰色:没引用白色:待分配回收前:对整个引用空间不连续的堆对象遍历回收后:引用的对象空间不变,清除:对全......
  • 学习笔记:计算机内存管理
    虚拟内存    单片机是没有操作系统的,所以每次写完代码,都需要借助工具把程序烧录进去,这样程序才能跑起来。        单片机的CPU是直接操作内存的「物理地址」。        在这种情况下,要想在内存中同时运行两个程序是不可能的。如果第一个程序在20......
  • linux 内存和cpu信息
    free#free[root@VM-0-14-centos~]#freetotalusedfreesharedbuff/cacheavailableMem:101482027236082932512659528577780Swap:000#-h以合适......
  • 【操作系统】MMAP内存映射|零拷贝
     ......
  • 芝奇Trident Z5 Royal DDR5-7200 C36 48GB内存上手:性能猛如虎
    DDR5已经上市很久了,消费者对DDR5内存的要求也越来越高。不仅对内存的频率要求高,对颜值的期待也不小。最近芝奇在今年的台北电脑展发布了全新一代的RGB内存,在颜值上再次走在了所有内存厂商的前面。同时,首发规格最高达8400MT/s,兼具时尚外观与极致性能。今天,我们有幸上手了芝奇的最......
  • 【C++修行之道】C/C++内存管理
    目录一、C/C++内存分布 1.选择题: 2.填空题: 3.sizeof和strlen区别? 二、C语言中动态内存管理方式:malloc/calloc/realloc/free 1.malloc/calloc/realloc的区别是什么?2.这里需要free(p2)吗?三、C++内存管理方式3.1new/delete操作内置类型3.2new和delete操作......
  • C/C++ 内存安全注意事项
    C/C++内存安全相关的注意事项主要如下:避免数组越界访问:数组越界是一种常见的安全漏洞,可能导致程序崩溃或被黑客利用。在访问数组元素时,应确保下标值不超过数组的边界。可以使用边界检查或安全的访问函数来预防此类问题。防止内存泄漏:C/C++中,内存管理需要程序员手动进行。......
  • 鸿蒙内核源码分析(内存汇编篇) | 谁是虚拟内存实现的基础
    ARM-CP15协处理器ARM处理器使用协处理器15(CP15)的寄存器来控制cache、TCM和存储器管理。CP15的寄存器只能被MRC和MCR(MovetoCoprocessorfromARMRegister)指令访问,包含16个32位的寄存器,其编号为0~15。本篇重点讲解其中的C7,C2,C13三个寄存器。先拆解一段汇编代码上来......
  • 华为---OSPF单区域配置(一)
    09、OSPF9.1OSPF单区域配置9.1.1原理概述为了弥补距离矢量路由协议的不足,IETF组织开发了一种基于链路状态的内部网关协议——OSPF(OpenShortestPathFirst,开放式最短路径优先)。OSPF作为基于链路状态的协议,具有收敛快、路由无环、扩展性好等优点,被快速接受并广泛使用......
  • 总公司与分公司跨区域互连,如何用Cisco Packet Tracer模拟实现呢?
    需求说明:某企业有公司总部和分公司且两个距离较远。公司总部及分公司的主机IP地址不在同一个网段,所有的信息端口连接在各自的的交换机上。因分公司要访问公司总部服务器的数据,这就要求公司总部与分公司之间要实现跨区域的互连互通,究竟如何才能实现呢?需求分析:如果是局域网中......