iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Java堆栈内存、堆外内存、零拷贝的示例分析
  • 124
分享到

Java堆栈内存、堆外内存、零拷贝的示例分析

2023-06-15 01:06:15 124人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关Java堆栈内存、堆外内存、零拷贝的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、堆栈内存堆栈内存,顾名思义,指的是堆内存以及栈内存,其中,堆内存是由Java GC

这篇文章将为大家详细讲解有关Java堆栈内存、堆外内存、零拷贝的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、堆栈内存

堆栈内存,顾名思义,指的是堆内存以及栈内存,其中,堆内存是由Java GC进行管理的内存区域,而栈内存则是线程内存。关于栈内存,这里不去细说。以Hotspot为例,堆内存的简要结构如下图所示:

Java堆栈内存、堆外内存、零拷贝的示例分析

而堆栈的关系,我们可以通过一行简单的代码来理解:

public static void main(String[] args) {    Object o = new Object();}

上述代码主要完成了两件事,new Object( ) 在堆上开辟了一块内存,也就是说,new Object( )是分配在堆上的;而变量o,则是在线程main的栈上面的,它指向了new Object( ) 开辟的堆内存地址。简单来说,程序中创建的对象,都存储在堆内存中,栈内存包含对它的引用。

二、堆外内存

简单来说,除了堆栈内存,剩下的就都是堆外内存了(当然,这是从Java运行时内存的角度来看),堆外内存直接受操作系统管理,而不是虚拟机。而使用堆外内存的原因,主要有几点:

  • 一定程度上减少了GC,堆外内存是直接受操作系统管理的,而不是JVM,因此使用堆外内存的话,就可以保持一个比较小的堆内内存,减少垃圾回收对程序性能的影响。这一块,在kafka中就应用得很好,感兴趣的同学可以去了解一下;

  • 还有一个更大的优点,就是提高io操作的效率!这里就涉及用户态与内核态,以及内核缓冲区的概念,具体可以看笔者之前的一篇文章Java随笔记 - 内核缓冲区与进程缓冲区。其中,堆内内存其实就是用户进程的进程缓冲区,属于用户态,而堆外内存由操作系统管理,属于内核态。如果从堆内向磁盘写数据,数据会被先复制到堆外内存,即内核缓冲区,然后再由OS写入磁盘,但使用堆外内存的话则可以避免这个复制操作。

Java堆栈内存、堆外内存、零拷贝的示例分析

三、零拷贝

总结上述内容中对堆栈内存与堆外内存的说明,主要解决了两个疑问:“零拷贝”是从哪拷贝到哪?“零拷贝”是怎么优化掉这一拷贝操作的?

  • 用户进程需要像磁盘写数据时,需要将用户缓冲区(堆内内存)中的内容拷贝到内核缓冲区(堆外内存)中,操作系统再将内核缓冲区中的内容写进磁盘中;

  • 通过在用户进程中,直接申请堆外内存,存储其需要写进磁盘的数据,就能够省掉上述拷贝操作。

在Java中,提供了一些使用堆外内存以及DMA的方法,能够在很大程度上优化用户进程的IO效率。这里,给出一份拷贝文件的代码,分别使用BIO、NIO和使用堆外内存的NIO进行文件复制,简单对比其耗时。

这里我使用一个200MB左右的pdf文件进行拷贝操作,你可以另外指定更大的文件,文件越大对比越明显。这里我运行出来的延时,BIO的平均耗时1500ms上下,NIO耗时120ms左右, 使用堆外内存的NIO耗时100ms上下。

package top.jiangnanmax.nio;import java.io.*;import java.nio.MappedByteBuffer;import java.nio.channels.FileChannel;public class CopyCompare {    public static void main(String[] args) throws Exception {        String inputFile = "/tmp/nio/input/HyperLedger.pdf";        String outputFile = "/tmp/nio/output/HyperLedger.pdf";        long start = System.currentTimeMillis();        niocopyByDirectMem(inputFile, outputFile);        long end = System.currentTimeMillis();        System.out.println("cost time: " + (end - start) + " ms");        deleteFile(outputFile);    }        private static void bioCopy(String sourcePath, String destPath) throws Exception {        File sourceFile = new File(sourcePath);        File destFile = new File(destPath);        if (!destFile.exists()) {            destFile.createNewFile();        }        FileInputStream inputStream = new FileInputStream(sourceFile);        FileOutputStream outputStream = new FileOutputStream(destFile);        byte[] buffer = new byte[512];        int lenRead;        while ((lenRead = inputStream.read(buffer)) != -1) {            outputStream.write(buffer, 0, lenRead);        }        inputStream.close();        outputStream.close();    }        private static void nioCopy(String sourcePath, String destPath) throws Exception {        File sourceFile = new File(sourcePath);        File destFile = new File(destPath);        if (!destFile.exists()) {            destFile.createNewFile();        }        FileInputStream inputStream = new FileInputStream(sourceFile);        FileOutputStream outputStream = new FileOutputStream(destFile);        FileChannel inputChannel = inputStream.getChannel();        FileChannel outputChannel = outputStream.getChannel();        // transferFrom底层调用的应该是sendfile        // 直接在两个文件描述符之间进行了数据传输        // DMA        outputChannel.transferFrom(inputChannel, 0, inputChannel.size());        inputChannel.close();        outputChannel.close();        inputStream.close();        outputStream.close();    }        private static void nioCopyByDirectMem(String sourcePath, String destPath) throws Exception {        File sourceFile = new File(sourcePath);        File destFile = new File(destPath);        if (!destFile.exists()) {            destFile.createNewFile();        }        FileInputStream inputStream = new FileInputStream(sourceFile);        FileOutputStream outputStream = new FileOutputStream(destFile);        FileChannel inputChannel = inputStream.getChannel();        FileChannel outputChannel = outputStream.getChannel();        MappedByteBuffer buffer = inputChannel.map(FileChannel.MapMode.READ_ONLY, 0, inputChannel.size());        outputChannel.write(buffer);        inputChannel.close();        outputChannel.close();        inputStream.close();        outputStream.close();    }        private static void deleteFile(String target) {        File file = new File(target);        file.delete();    }}

java基本数据类型有哪些

Java的基本数据类型分为:1、整数类型,用来表示整数的数据类型。2、浮点类型,用来表示小数的数据类型。3、字符类型,字符类型的关键字是“char”。4、布尔类型,是表示逻辑值的基本数据类型。

关于“Java堆栈内存、堆外内存、零拷贝的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: Java堆栈内存、堆外内存、零拷贝的示例分析

本文链接: https://www.lsjlt.com/news/276690.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java堆栈内存、堆外内存、零拷贝的示例分析
    这篇文章将为大家详细讲解有关Java堆栈内存、堆外内存、零拷贝的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、堆栈内存堆栈内存,顾名思义,指的是堆内存以及栈内存,其中,堆内存是由Java GC...
    99+
    2023-06-15
  • 详细总结Java堆栈内存、堆外内存、零拷贝浅析与代码实现
    目录一、堆栈内存二、堆外内存三、零拷贝一、堆栈内存 堆栈内存,顾名思义,指的是堆内存以及栈内存,其中,堆内存是由Java GC进行管理的内存区域,而栈内存则是线程内存。关于栈内存,这...
    99+
    2024-04-02
  • JavaScript中堆栈与拷贝的示例分析
    小编给大家分享一下JavaScript中堆栈与拷贝的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一.堆栈的定义栈是一种特殊的线性表。其特殊性在于限定插入...
    99+
    2023-06-15
  • PHP 内存分配类型:堆栈和堆
    内存分配是编程的一个重要方面,它决定了程序如何管理和使用内存。 在 PHP 中,有两种主要的内存分配类型:堆栈和堆。 堆栈 堆栈是一种内存分配类型,用于存储局部变量和函数参数。 在 PHP 中...
    99+
    2024-02-27
  • Node中堆内存分配的示例分析
    这篇文章将为大家详细讲解有关Node中堆内存分配的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。V8 垃圾回收简介首先,简单介绍一下V8垃圾回收器。内存的存储分配...
    99+
    2024-04-02
  • java堆内存和栈内存有什么区别
    Java中的堆内存和栈内存是两种不同的内存区域,主要用于存储不同类型的数据。1. 堆内存(Heap Memory):- 用于存储对象实例和数组等动态分配的数据。- 由Java虚拟机自动管理,通过垃圾回收机制来释放不再使用的对象占用的内存...
    99+
    2023-08-11
    java
  • Java中栈内存和堆内存有什么区别
    在Java中,栈内存和堆内存是两种不同的内存区域,用于存储不同类型的数据。1. 栈内存:- 栈内存是由系统自动分配和释放的,用于存储...
    99+
    2023-08-16
    Java
  • 调试排错 - Java 内存分析之堆内存和MetaSpace内存
    本文以两个简单的例子(堆内存溢出和MetaSpace (元数据) 内存溢出)解释Java 内存溢出的分析过程。@pdai调试排错 - Java 内存分析之堆内存和MetaSpace内存常见的内存溢出问题(内存和MetaSpace内...
    99+
    2022-12-02
    java框架 java全栈 java学习路线 java全栈知识 java面试 知识体系 java技术体系 java编程
  • C标准库堆内存函数的示例分析
    这篇文章主要为大家展示了“C标准库堆内存函数的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“C标准库堆内存函数的示例分析”这篇文章吧。概述C标准库堆内存函数有4个:malloc、free...
    99+
    2023-06-15
  • C++程序内存栈区与堆区模型案例分析
    目录栈区:栈区代码演示:堆区:堆区代码演示:new操作符:new操作符代码演示:栈区: 由编译器自动分配释放,存放函数的参数值,局部变量等(由编译器管理其“生死&rdqu...
    99+
    2024-04-02
  • Netty对JDK缓冲区中内存池零拷贝优化的示例分析
    这篇文章主要介绍Netty对JDK缓冲区中内存池零拷贝优化的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!NIO中缓冲区是数据传输的基础,JDK通过ByteBuffer实现,Netty框架中并未采用JDK原生...
    99+
    2023-06-04
  • Java DirectByteBuffer堆外内存回收详解
    目录PhantomReference虚引用DirectByteBuffer堆外内存回收CleanerreserveMemory内存清理PhantomReference虚引用 在分析堆...
    99+
    2024-04-02
  • JVM堆外内存源码完全解读分析
    概述 广义的堆外内存 说到堆外内存,那大家肯定想到堆内内存,这也是我们大家接触最多的,我们在jvm参数里通常设置-Xmx来指定我们的堆的最大值,不过这还不是我们理解的Java堆,-X...
    99+
    2024-04-02
  • Linux中堆栈的示例分析
    这篇文章给大家分享的是有关Linux中堆栈的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。用下面的程序作为例子:void a() {    &n...
    99+
    2023-06-16
  • java堆外内存泄漏怎么排查
    在Java中,堆外内存通常是通过直接内存(Direct Memory)分配的。直接内存是一种不受Java堆内存管理的内存分配方式,它...
    99+
    2023-10-27
    java
  • java堆外内存泄漏如何排查
    在Java中,堆外内存泄漏通常是由于未正确释放使用了堆外内存的资源所导致的。下面是一些排查堆外内存泄漏的常见方法:1. 使用JVM工...
    99+
    2023-08-24
    java
  • JS堆栈内存的运行机制详解
    目录栈内存 ECStack堆内存数据类型创建步骤在js引擎中对变量的存储主要有两个位置,堆内存和栈内存。栈内存主要用于存储各种基本类型的变量,包括Boolean、Number、Str...
    99+
    2024-04-02
  • JavaScript中内存空间、赋值和深浅拷贝的示例分析
    这篇文章将为大家详细讲解有关JavaScript中内存空间、赋值和深浅拷贝的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript的内存空间在Java...
    99+
    2024-04-02
  • 浅谈Java堆外内存之突破JVM枷锁
    对于有Java开发经验的朋友都知道,Java中不需要手动的申请和释放内存,JVM会自动进行垃圾回收;而使用的内存是由JVM控制的。那么,什么时机会进行垃圾回收,如何避免过度频繁的垃圾回收?如果JVM给的内存不够用,怎么办?此时,堆外内存登场...
    99+
    2023-05-30
    java jvm 堆外内存
  • Java生成堆内存dump的问题
    目录Java生成堆内存dump那么java如何打出dump文件呢?jvm生成dump文件出现OOM时自动生成堆dump人工通过执行指令,直接生成当前JVM的dump文件总结Java生...
    99+
    2022-12-29
    Java dump Java堆内存dump Java堆内存
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作