`
chenzehe
  • 浏览: 539842 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Heap Buffer和Direct Buffer

 
阅读更多

1、Heap Buffer

堆内存字节缓冲区,可以被JVM自动回收,特点是内存的分配和回收速度快,缺点是如果进行Socket的I/O读写,需要额外的做一次内存复制,将堆内存对应的缓存区复制到内核Channel中,性能会有一定程度的下降。

 

2、Direct Buffer

直接内存字节缓冲区,非堆内存,在堆外进行内存分配和回收,相比于堆内存,它的分配和回收速度会慢一些,但是将它写入或者从Socket Channel中读取时,由于少了一次内存复制,速度比堆内存快。

 

JDK1.4中新引入NIO类库,引入了一种基于通道(Channel)和缓冲区(Buffer)的I/O方式,它可以使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆里面的DirectByteBuffer对象作为这块内存的引用进行操作,也可能导致OOM异常。

 

下图为Netty提供的多种ByteBuf供使用,最佳实践是在I/O通信线程的读写到缓冲区使用Direct Buffer,后端的业务消息编解码模块使用Heap Buffer,这样组合使用能达到最优性能。

 

分享到:
评论

相关推荐

    缓冲池 java

    Buffer分为两种类型:Heap Buffer和Direct Buffer。Heap Buffer存储在Java堆中,而Direct Buffer存储在系统内存中,直接与硬件交互,减少了Java虚拟机(JVM)的内存拷贝,提高了性能。然而,Direct Buffer可能会占用...

    第12讲 Java有几种文件拷贝方式?哪一种最高效?1

    Buffer在Java.NIO中扮演重要角色,分为Heap Buffer和Direct Buffer。Heap Buffer存储在JVM堆中,而Direct Buffer则直接在操作系统分配的内存中,这使得它对内存管理的影响较小,对于大容量数据处理时,Direct Buffer...

    java代码-buffer

    Java NIO提供了两种Buffer类型:Heap Buffer和Direct Buffer。Heap Buffer在Java堆内存中创建,而Direct Buffer在操作系统堆外内存中创建,减少了系统调用的开销,适用于大容量数据传输。 6. **实战应用** - 文件...

    java 中Buffer源码的分析

    Buffer 是 Java 中一个非常重要的知识点,Direct Buffer 和 Heap Buffer 是两种不同的 Buffer,Direct Buffer 可以提高效率和减少GC 的频率,而 Heap Buffer 需要进行数据复制,因此效率较低。在实际开发中,应该...

    netty-code源码

    7. **零拷贝(Zero-Copy)**:Netty通过DirectBuffer和FileRegion实现零拷贝技术,减少了数据在内存中的复制,提高了性能。 8. **ChannelFuture和Promise**:ChannelFuture表示异步操作的结果,而Promise则用于设置...

    Netty权威指南 (第2版)

    - 内存管理:DirectBuffer与HeapBuffer的选择 - 零拷贝技术:FileRegion和ByteBuf的使用 - 线程模型优化:EventLoopGroup的配置 - 长连接管理:心跳检测和超时策略 6. **Netty实战应用** - 构建Web服务器和...

    Netty 35道面试题和答案.docx

    Netty是一个高性能、异步事件...HeapBuffer由JVM管理,适用于数据量较小的情况。Selector的register方法用于向选择器注册通道并设置监听事件,SelectionKey代表了注册关系,wakeup方法用于唤醒被阻塞的Selector线程。

    JavaNio视频下载_百度云盘资源

    - **Heap Buffer**:堆缓冲区则是在Java堆上分配的内存。 #### Channel Channel是Java NIO中的另一个核心概念,它类似于传统的流(Stream),但功能更加强大。Channel提供了一种从文件系统、网络或其他来源传输...

    系统稳定性——OutOfMemoryError常见原因及解决方法1

    【系统稳定性——OutOfMemoryError常见原因及解决方法】 在Java应用程序中,系统稳定性的一个关键因素是避免出现`...通过理解和应用上述方法,可以有效地预防和解决这类问题,从而提升应用的性能和可用性。

    JAVA常见错误(方便开发人员查找问题,也方便测试人员对bug进行描述)

    该错误是由于Heap内存溢出,意味着Young和Old generation的内存不够。解决方法是调整java启动参数-Xms和-Xmx来增加Heap内存。 2. java.lang.OutOfMemoryError: unable to create new native thread 该错误是由于...

    netty各种例子(基于netty各种例子。).zip

    7. **内存管理**:Netty通过DirectBuffer和HeapBuffer实现了高效的内存管理,减少了不必要的系统调用。 8. **流式API**:Netty的API设计为流式,使得编写处理流程更加直观。 9. **错误处理**:Netty提供了优雅的...

    MySQL 内存分析

    例如,read_buffer和read_rnd_buffer用于优化MyISAM表的读取操作。join_buffer_size和sort_buffer_size则分别用于优化联结操作和排序操作。为这些缓冲区分配合适的内存大小对于提高查询性能有着直接的影响。 除此...

    关于java堆内存溢出的几种情况

    【情况四】:`java.lang.OutOfMemoryError: Direct buffer memory` 这种情况发生在NIO(非阻塞I/O)中,因为直接缓冲区内存分配失败。可以通过设置`-XX:MaxDirectMemorySize`参数来限制直接内存大小,如`-XX:...

    使用Direct3D12实施动态资源

    Direct3D12是Microsoft开发的一个图形应用程序接口(API),它为Windows平台提供了高效且低级别的硬件访问,用于创建和管理3D图形。本篇将详细探讨如何利用Direct3D12实现动态资源,特别是通过使用环形缓冲区(Ring ...

    缓冲区算法代码

    2. **缓冲区类型**:如直接缓冲区(Direct Buffer)与非直接缓冲区(Heap Buffer),它们在Java中是如何实现的,以及各自的优缺点。 3. **缓冲区管理**:如何创建、使用和释放缓冲区,以及在多线程环境下的同步问题...

    Java_NIO_API详解

    NIO提供了一种基于缓冲区(Buffer)的非阻塞I/O操作机制,极大地提高了I/O处理的性能和效率。本文将详细介绍NIO的主要组成部分及其实现原理,帮助开发者更好地理解和应用NIO技术。 #### 二、NIO API概述 NIO API...

    Netty面试专题.zip

    - **Direct Buffer和Heap Buffer**:Netty支持直接内存和堆内存,直接内存避免了JVM和操作系统之间的数据拷贝,提高性能。 - **FileRegion**:用于传输文件,实现零拷贝,减少了内存与磁盘之间的数据复制。 5. **...

    Java内存溢出解决办法

    可以通过设置-Dsun.nio.ch maks.directBufferCount和-Djnio-direct-buffer-size来限制直接内存。 解决Java内存溢出问题通常需要以下步骤: 1. **识别问题**:通过异常信息定位是哪种类型的内存溢出,结合日志和...

Global site tag (gtag.js) - Google Analytics