热门标签 | 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



推荐阅读
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 2017-2018年度《网络编程与安全》第五次实验报告
    本报告详细记录了2017-2018学年《网络编程与安全》课程第五次实验的具体内容、实验过程、遇到的问题及解决方案。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 开发笔记:9.八大排序
    开发笔记:9.八大排序 ... [详细]
  • ElasticSearch 集群监控与优化
    本文详细介绍了如何有效地监控 ElasticSearch 集群,涵盖了关键性能指标、集群健康状况、统计信息以及内存和垃圾回收的监控方法。 ... [详细]
  • 本文介绍了一种基于选择排序思想的高效排序方法——堆排序。通过使用堆数据结构,堆排序能够在每次查找最大元素时显著提高效率。文章详细描述了堆排序的工作原理,并提供了完整的C语言代码实现。 ... [详细]
  • 深入理解Java多线程并发处理:基础与实践
    本文探讨了Java中的多线程并发处理机制,从基本概念到实际应用,帮助读者全面理解并掌握多线程编程技巧。通过实例解析和理论阐述,确保初学者也能轻松入门。 ... [详细]
  • 深入剖析JVM垃圾回收机制
    本文详细探讨了Java虚拟机(JVM)中的垃圾回收机制,包括其意义、对象判定方法、引用类型、常见垃圾收集算法以及各种垃圾收集器的特点和工作原理。通过理解这些内容,开发人员可以更好地优化内存管理和程序性能。 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文总结了Java程序设计第一周的学习内容,涵盖语言基础、编译解释过程及基本数据类型等核心知识点。 ... [详细]
  • 本文作者分享了在阿里巴巴获得实习offer的经历,包括五轮面试的详细内容和经验总结。其中四轮为技术面试,一轮为HR面试,涵盖了大量的Java技术和项目实践经验。 ... [详细]
  • 本文详细探讨了Java中的ClassLoader类加载器的工作原理,包括其如何将class文件加载至JVM中,以及JVM启动时的动态加载策略。文章还介绍了JVM内置的三种类加载器及其工作方式,并解释了类加载器的继承关系和双亲委托机制。 ... [详细]
  • 本文详细介绍了如何正确配置Java环境变量PATH,以确保JDK安装完成后能够正常运行。文章不仅涵盖了基本的环境变量设置步骤,还提供了针对不同操作系统下的具体操作指南。 ... [详细]
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社区 版权所有