热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaNIOBuffer分配详解:allocate与allocateDirect的区别与应用

在JavaNIO中,`ByteBuffer`的内存分配方式分为`allocate`和`allocateDirect`。前者在JVM堆内存中分配空间,返回`HeapByteBuffer`实例,初始位置为0,容量和限制由参数指定。而`allocateDirect`则在操作系统本地内存中分配,返回`DirectByteBuffer`,适用于需要频繁与I/O操作交互的场景,性能更高但管理成本较大。两者在内存管理和性能上各有优劣,选择时需根据具体应用场景权衡。

一、nio之Buffer

1 ByteBuffer.allocate分配的内存在JVM里面,返回ByteBuffer的子类HeapByteBuffer,初始值0;

2 ByteBuffer.allocateDirect分配的内存在系统里面,返回MappedByteBuffer的子类DirectByteBuffer,初始值0;

3 系统内存分配速度慢,但使用效率更高,并且不参与垃圾回收;

4 buffer的四个属性&#xff0c;0 <&#61; mark <&#61; position <&#61; limit <&#61; capacity&#xff0c;position决定了read和write的起始位置&#xff1b;

5 mark用于reset使用&#xff0c;没有mark调用reset会抛异常&#xff0c;初始状态无标记&#xff0c;只有position小于mark时标记被丢弃&#xff1b;

6 buffer.get()和buffer.put(byte)都是相对方法&#xff0c;都会导致position&#43;&#43;&#xff1b;

7 buffer.get(int)和buffer.put(int, byte)都是绝对方法&#xff0c;不会导致position变化&#xff1b;

8 clear只是将position设置为0&#xff0c;limit设置为capacity&#xff0c;并不清除数据&#xff0c;做好put准备&#xff1b;

9 flip将limit设置为position&#xff0c;position设置为0&#xff0c;做好get准备&#xff1b;

10 rewind将position设置为0&#xff0c;做好重新get准备&#xff1b;

11 remaining表示position到limit之间的元素数量&#xff1b;

12 compact将position到limit之间的元素移动到数组开始&#xff1b;

13 多线程访问是不安全的&#xff0c;需要使用同步手段进行控制&#xff1b;

14 ByteOrder.nativeOrder()获取本机字节序列&#xff1b;

15 视图和allocateDirect情况下hasArray返回false&#xff1b;

16 array()方法返回底层数组&#xff1b;

1 属性测试&#xff1a;

ByteBuffer buffer &#61; ByteBuffer.allocate(12);

System.out.println(buffer);

System.out.println(buffer.position(2).mark());

System.out.println(buffer.position(4));

System.out.println(buffer.reset());

System.out.println(buffer.position(0));

buffer.reset(); //抛出InvalidMarkException异常

输出&#xff1a;

java.nio.HeapByteBuffer[pos&#61;0 lim&#61;12 cap&#61;12]

java.nio.HeapByteBuffer[pos&#61;2 lim&#61;12 cap&#61;12]

java.nio.HeapByteBuffer[pos&#61;4 lim&#61;12 cap&#61;12]

java.nio.HeapByteBuffer[pos&#61;2 lim&#61;12 cap&#61;12]

java.nio.HeapByteBuffer[pos&#61;0 lim&#61;12 cap&#61;12]

2 数据操作&#xff0c;默认大端模式&#xff1a;

ByteBuffer buffer &#61; ByteBuffer.allocate(12);

byte by &#61; 1;

int in &#61; 32;

buffer.put(by);

buffer.putInt(in);

System.out.println(buffer);

System.out.println(buffer.get(4));

输出&#xff1a;

java.nio.HeapByteBuffer[pos&#61;5 lim&#61;12 cap&#61;12]

32

3duplicate复制原buffer所有状态&#xff0c;slice将position和limit之间的内容映射成新buffer&#xff0c;两者都使用原来内存&#xff1a;

1、duplicate复制mark值&#xff0c;slice清除mark值&#xff1b;

2、asReadOnlyBuffer与duplicate完成相同&#xff0c;除了缓冲区只读以外&#xff1b;

ByteBuffer buffer &#61; ByteBuffer.allocate(12);

byte by &#61; 1;

int in &#61; 32;

buffer.put(by);

buffer.putInt(in);

System.out.println(buffer);

System.out.println(buffer.array());

System.out.println(buffer.duplicate());

System.out.println(buffer.duplicate().array());

buffer.position(4);

System.out.println(buffer.slice());

System.out.println(buffer.slice().array());

System.out.println(buffer.slice().arrayOffset());

输出&#xff1a;

java.nio.HeapByteBuffer[pos&#61;5 lim&#61;12 cap&#61;12]

[B&#64;1c0ec97

java.nio.HeapByteBuffer[pos&#61;5 lim&#61;12 cap&#61;12]

[B&#64;1c0ec97

java.nio.HeapByteBuffer[pos&#61;0 lim&#61;8 cap&#61;8]

[B&#64;1c0ec97

4

4 数组转换到ByteBuffer

byte[] bytes &#61; new byte[12];

ByteBuffer buf &#61; ByteBuffer.wrap(bytes, 1, 1);

System.out.println(buf);

System.out.println(bytes);

System.out.println(buf.array());

System.out.println(buf.arrayOffset());

输出&#xff1a;

java.nio.HeapByteBuffer[pos&#61;1 lim&#61;2 cap&#61;12]

[B&#64;ecb281

[B&#64;ecb281

0

5 大小端

ByteBuffer buf &#61; ByteBuffer.allocate(12);

System.out.println(buf.order());

System.out.println(buf.order(ByteOrder.LITTLE_ENDIAN).order());

输出&#xff1a;

BIG_ENDIAN

LITTLE_ENDIAN

6 IntBuffer测试

ByteBuffer buffer &#61; ByteBuffer.allocate(16);

buffer.position(4);

IntBuffer intBuf &#61; buffer.asIntBuffer();

System.out.println(intBuf);

System.out.println(intBuf.order());

System.out.println(intBuf.hasArray());

intBuf &#61; IntBuffer.allocate(4);

System.out.println(intBuf);

System.out.println(intBuf.order());

System.out.println(intBuf.hasArray());

输出&#xff1a;

java.nio.ByteBufferAsIntBufferB[pos&#61;0 lim&#61;3 cap&#61;3]

BIG_ENDIAN

false

java.nio.HeapIntBuffer[pos&#61;0 lim&#61;4 cap&#61;4]

LITTLE_ENDIAN

true

7 compareTo对所有元素进行比较

ByteBuffer buf1 &#61; ByteBuffer.allocate(4);

ByteBuffer buf2 &#61; ByteBuffer.allocateDirect(4);

IntBuffer buf3 &#61; IntBuffer.allocate(1);

System.out.println(buf1.compareTo(buf2));

System.out.println(buf1.asIntBuffer().compareTo(buf3));

输出&#xff1a;

0

0



推荐阅读
  • 【技术解析】深入探讨堆利用中的UAF漏洞及其影响 ... [详细]
  • 在使用 PHP 通过 SSL 安全连接到 MySQLi 数据库服务器时,遇到了一些技术难题。我的环境包括一个 Web 服务器和一个数据库服务器,两者均使用 OpenSSL 生成了证书。尽管证书内容一致,但在尝试从 Web 服务器使用 `mysql` 命令进行连接时,仍然遇到了问题。为了确保连接的安全性和稳定性,需要进一步检查证书配置和 PHP 的 SSL 设置,以排除潜在的配置错误或兼容性问题。 ... [详细]
  • Java NIO Buffer详解及其优势与局限性分析 ... [详细]
  • Oracle培训(三十七)——深入解析Hibernate第三章:实体关联关系映射详解
    在本节Oracle培训中,我们将深入探讨Hibernate第三章的内容,重点讲解实体关联关系映射的详细知识点。首先,回顾了Hibernate的基本概念和映射基础,随后详细分析了不同类型的实体关联关系,包括一对一、一对多和多对多关系的映射方法及其应用场景。通过具体的示例和代码片段,帮助读者更好地理解和掌握这些复杂的映射技术。此外,还讨论了如何优化关联关系的性能,以及常见的问题和解决方案。 ... [详细]
  • 通过Apache Commons FileUpload组件,可以根据具体应用需求实现多样化的文件上传功能。在基本应用场景中,开发者可以通过调用单一方法来解析Servlet请求,从而轻松处理文件上传任务。此外,该组件还提供了丰富的配置选项和高级功能,支持大文件上传、多文件并发处理等复杂场景,显著提升了文件上传的效率和可靠性。 ... [详细]
  • 本文深入解析了Java编译过程,重点探讨了从源代码到字节码文件的转换机制。通过具体示例,如 `Hello.java` 的编译与反编译过程,详细介绍了 `javap -verbose` 命令的使用方法及其在字节码分析中的重要作用。此外,文章还讨论了字节码文件的结构特点及其在不同应用场景中的实际应用,为开发者提供了宝贵的参考。 ... [详细]
  • Panabit应用层流量管理解决方案
    Panabit是一款国内领先的应用层流量管理解决方案,提供高度开放且免费的专业服务,尤其擅长P2P应用的精准识别与高效控制。截至2009年3月25日,该系统已实现对多种网络应用的全面支持,有效提升了网络资源的利用效率和安全性。 ... [详细]
  • 深入解析JDK中的四种随机数生成器
    我们从jdk8说起。主要是四个随机数生成器。神马?有四个? 接下来我们简单说下这几个类的使用场景,来了解其中的细微差别,和a ... [详细]
  • 1、字段类型概述 一级分类二级分类具体类型核心类型字符串类型string,text,keyword整数类型integer,long,short,byte浮点类型double,flo ... [详细]
  • CatchThatCowTimeLimit:50002000MS(JavaOthers)MemoryLimit:3276832768K(JavaOt ... [详细]
  • 探讨 javax.jms.JMSException 中 getLocalizedMessage 方法的应用与实例代码分析 ... [详细]
  • 如何在Linux系统中辨别服务器是否为虚拟机或物理机
    在Linux系统中,可以通过执行特定命令来判断服务器是物理机还是虚拟机。例如,在CentOS系统中,运行 `dmidecode | grep -A16 "System Information"` 命令,查看输出中的“Manufacturer”和“Product Name”字段,这些信息可以帮助用户准确区分服务器的类型。此外,还可以通过检查 `/sys/devices/virtual/dmi/id` 目录下的文件内容,进一步确认服务器的具体型号和制造商信息。 ... [详细]
  • c#学Java–Java基本语法1.类比JAVA .NETJVM CLRJDK  FCL2.java命名约定类名称应以大写字母开头,并成为容易理解的名词或组合。如 ... [详细]
  • Joomla!软件介绍【Joomla!概括介绍】国外相当知名的内容管理系统。【Joomla!基本介绍】Joomla!是一套在国外相当知名的内容管理系统(ContentManagem ... [详细]
  • 【网络技术】VLAN与以太网交换机的工作机制解析
    拓补说明如图。PC1和PC3同处VLAN10,PC2和PC4同处VLAN20,4台PC的IP地址同处在10.10.10.024的这个IP地址段中。PC1和PC2通过交换机1接入网络 ... [详细]
author-avatar
单色设计
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有