JVM工作原理与实战(二十):直接内存

简介: JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了直接内存、在直接内存上创建数据等内容。

一、直接内存

在探讨直接内存之前,首先需要理解Java虚拟机(JVM)的运行时数据区。在《Java虚拟机规范》中,定义了几个关键的内存区域,如堆、方法区、程序计数器、Java虚拟机栈和本地方法栈。但直接内存,这一概念并不直接包含在《Java虚拟机规范》中。实际上,直接内存更多地是Java内存管理中的一个高级特性。

运行时数据区:


1.直接内存作用

直接内存(Direct Memory)的引入与JDK 1.4中的新IO(NIO)机制紧密相关。NIO为Java提供了非阻塞的I/O操作,从而允许更高的并发性和更高效的I/O处理。而直接内存正是NIO实现的关键部分:

  • 解决对象回收问题:在Java中,当堆上的对象不再被引用时,这些对象将被标记为可回收。这个过程可能会影响正在运行的应用程序,因为垃圾回收器可能需要停止或阻塞应用程序线程以完成其工作。直接内存通过减少堆上的对象数量来减轻这种影响。通过将数据直接存储在直接内存中,应用程序可以持续运行,而不必担心垃圾回收器可能带来的暂停或阻塞。
  • 减少数据复制开销:传统的IO操作,如读取文件,通常涉及两个步骤:首先将数据从文件读入到缓冲区(通常是直接内存),然后再从缓冲区复制到Java堆上的对象。这种双重数据复制不仅增加了延迟,还增加了CPU和内存的使用。通过使用直接内存作为缓冲区,NIO可以直接在直接内存中处理数据,从而减少了数据从缓冲区到堆的复制过程,提高了IO操作的效率。

image.gif

直接内存的出现不仅提高了Java应用程序的性能,而且也增加了应用程序对并发和大数据处理的适应能力。通过使用直接内存,应用程序可以更有效地管理其资源,同时提高其响应速度和吞吐量。

二、在直接内存上创建数据

Java NIO提供了一种机制,允许在直接内存上创建数据。要实现这一目标,可以使用ByteBuffer的allocateDirect方法,size参数表示希望分配的直接内存的大小,单位为字节。

ByteBuffer directBuffer = ByteBuffer.allocateDirect(size);

image.gif

查看Java虚拟机的直接内存大小,可以使用arthas的memory命令,通过在命令行中输入memory来查看输出中的"direct"属性。

特殊情况下,可能需要手动调整直接内存的大小。可以通过设置JVM参数-XX:MaxDirectMemorySize来实现,这个参数允许开发者指定直接内存的最大大小。在设置-XX:MaxDirectMemorySize参数时,可以使用k或K表示千字节,m或M表示兆字节,g或G表示千兆字节,如果不设置这个参数,JVM会自动选择最大的分配大小。

案例:

public class Demo1 {
    public static int size = 1024 * 1024 * 100;
    public static List<ByteBuffer> list = new ArrayList<ByteBuffer>();
    public static int count = 0;
    public static void main(String[] args) throws IOException, InterruptedException {
        System.in.read();
        while (true) {
            ByteBuffer directBuffer = ByteBuffer.allocateDirect(size);
            list.add(directBuffer);
            System.out.println(++count);
        }
    }
}
image.gif

运行结果:

image.gif

设置直接内存的大小:

-XX:MaxDirectMemorySize=1g
image.gif

image.gif

运行结果:

image.gif

总结

JVM是Java程序的运行环境,负责字节码解释、内存管理、安全保障、多线程支持、性能监控和跨平台运行。本文主要介绍了直接内存、在直接内存上创建数据等内容,希望对大家有所帮助。

相关文章
|
3天前
|
存储 算法 安全
深入理解操作系统内存管理:原理与实践
【5月更文挑战第25天】 随着计算机技术的不断发展,操作系统在硬件资源管理中扮演着越来越重要的角色。其中,内存管理作为操作系统的核心功能之一,对于提高系统性能和稳定性具有重要意义。本文将深入探讨操作系统内存管理的基本原理,包括内存分配、内存回收、内存保护等方面,并通过实例分析如何在实际开发中优化内存管理策略,以提高系统运行效率。
|
4天前
|
存储 Java 对象存储
JVM(内存区域划分)
JVM(内存区域划分)
14 1
|
6天前
|
存储 安全 Java
synchronized原理-字节码分析、对象内存结构、锁升级过程、Monitor
本文分析的问题: 1. synchronized 字节码文件分析之 monitorenter、monitorexit 指令 2. 为什么任何一个Java对象都可以成为一把锁? 3. 对象的内存结构 4. 锁升级过程 (无锁、偏向锁、轻量级锁、重量级锁) 5. Monitor 是什么、源码查看(hotspot虚拟机源码) 6. JOL工具使用
|
1天前
|
存储 Java 开发者
深入理解Java虚拟机:JVM内存模型解析
【5月更文挑战第27天】 在Java程序的运行过程中,JVM(Java Virtual Machine)扮演着至关重要的角色。作为Java语言的核心执行环境,JVM不仅负责代码的执行,还管理着程序运行时的内存分配与回收。本文将深入探讨JVM的内存模型,包括其结构、各部分的作用以及它们之间的相互关系。通过对JVM内存模型的剖析,我们能够更好地理解Java程序的性能特征,并针对性地进行调优,从而提升应用的执行效率和稳定性。
|
1天前
|
Java
<Java SE> 5道递归计算,创建数组,数组遍历,JVM内存分配...
<Java SE> 5道递归计算,创建数组,数组遍历,JVM内存分配
20 2
|
1天前
|
并行计算 安全 大数据
深入理解操作系统内存管理:原理与实践
【5月更文挑战第27天】 在现代计算机系统中,操作系统的内存管理是确保系统高效、稳定运行的关键组成部分。本文旨在深入剖析操作系统内存管理的基本原理,并结合具体案例探讨内存管理的实践应用。文章首先介绍内存管理的基本概念,包括地址空间、虚拟内存和物理内存。随后,详细阐述不同的内存分配策略,如首次适应、最佳适应和伙伴系统,并分析各自的优势与局限性。文章还将探讨分页和分段机制的原理及其在现代操作系统中的应用,并通过实际代码示例展示如何在Linux内核中实现内存管理的关键技术。最后,讨论当前内存管理面临的挑战和未来可能的发展趋势。
|
2天前
|
内存技术
深入理解操作系统内存管理:原理与实践
【5月更文挑战第26天】 操作系统的内存管理是计算机科学中至关重要的一环,它不仅关系到系统性能的优化,还涉及到程序运行的稳定性与安全性。本文将深入探讨操作系统中的内存管理机制,包括物理内存与虚拟内存的映射关系、分页系统的工作原理以及内存分配策略。通过对这些概念的剖析和相关技术的实践指导,旨在帮助读者构建起对操作系统内存管理的深刻理解,并能够在实际工作中运用这些知识解决相关问题。
|
4天前
|
缓存 算法 Linux
深入理解操作系统内存管理:原理与实践
【5月更文挑战第25天】 本文旨在探讨操作系统中的关键组成部分——内存管理。我们将从内存管理的基本原理出发,逐步深入到实际操作系统如Windows和Linux中的内存管理策略。文章不仅涵盖了内存的分配、回收以及分页与分段机制,还对虚拟内存技术进行了详细的解析。通过理论与实例相结合的方式,读者能够获得对操作系统内存管理更为深刻的认识,并掌握其在实际系统中的应用。
|
5天前
|
存储 缓存 监控
深入理解操作系统内存管理:原理与实践
【5月更文挑战第23天】 在现代计算机系统中,内存管理是操作系统核心职能之一。本文将探讨操作系统内存管理的关键概念、技术细节及其在实际应用中的表现。我们将透过内存层次结构、分页机制和虚拟内存等关键技术,解析操作系统如何有效地管理有限的物理内存资源,同时提供高效、安全的运行环境给上层应用。文章旨在为读者提供一个清晰的框架来理解并评估不同的内存管理策略,以及它们对系统性能和稳定性的影响。
|
10天前
|
算法 程序员 内存技术
深入理解操作系统内存管理:原理与实践
【5月更文挑战第18天】 在现代计算机系统中,操作系统扮演着关键角色,其中内存管理作为其核心功能之一,保障了系统资源的高效利用和程序的顺利运行。本文旨在探讨操作系统内存管理的基本原理及其在实际中的应用,涉及物理内存的组织、虚拟内存技术的实现以及内存分配策略等关键技术点。通过分析不同内存管理机制的优势与局限,我们将对操作系统如何协调多任务环境下的内存使用有更深刻的认识。