Java NIO的基本概念与使用
public class TestBuffer {<span style="color:#808080;"><em>/**
* 一. 缓冲区 (Buffer):Java Nio中负责数据的 存取+缓冲就是数组.用于存储不同类型的数据
*
* 根据类型不同(boolean 除外) 都提供了对应的缓冲区
* ByteBuffer
* CharBuffer
* ShortBuffer
*
* LongBuffer
* FloatBuffer
* DoubleBuffer
*
* 上述缓冲区的管理方式 几乎一致 通过allocate()获取缓冲区
*
* 二.缓冲区存取数据的两个核心方法
* put():存入数据到缓冲区中
* get():获取 缓冲区中的数据
*
*
* 三.缓冲区4个核心方法(Class:Buffer)
* 1.capacity 容量,表示缓冲区中最大存储的容量 一旦声明不能改写
* 2.limit 界限, 表示缓冲区可以操作数据的大小.(limit 后数据不能进行读写)
* 3.position 位置,表示缓冲区 正在操作数据的位置
* 4.mark 标记 表示当前position的位置 可以通过reset()恢复到 mark的位置
*
* 0 <=mark<= position<= limit<=capacity
*
* 四.直接缓冲区与非直接缓冲区:
* 非直接缓冲区:通过 allocate() 方法分配缓冲区, 将缓冲区建立在JVM的内存中
* 直接缓冲区: 通过 allocateDirect() 方法分配直接缓冲区,将缓冲区建立在物理内存中.可以提高效率
*/
public static void main(String[] args){
String str= "Hello world";<span style="color:#808080;"><em>//1.</em></span><span style="color:#808080;font-family:'宋体';"><em>分配一个大小
ByteBuffer byteBuffer = ByteBuffer.allocate(1024);
System.out.println("--------------allocate初始化大小---------------");
System.out.println("position:"+byteBuffer.position());
System.out.println("limit:"+byteBuffer.limit());
System.out.println("capacity:"+byteBuffer.capacity());<span style="color:#808080;"><em>//2.</em></span><span style="color:#808080;font-family:'宋体';"><em>使用</em></span><span style="color:#808080;"><em>Put()</em></span><span style="color:#808080;font-family:'宋体';"><em>方法 存入缓冲区数据
byteBuffer.put(str.getBytes());
System.out.println("--------------allocate存入数据后的变化---------------");
System.out.println("position:"+byteBuffer.position());
System.out.println("limit:"+byteBuffer.limit());
System.out.println("capacity:"+byteBuffer.capacity());<span style="color:#808080;"><em>//3.</em></span><span style="color:#808080;font-family:'宋体';"><em>如要读取数据 需要切换模式 调用</em></span><span style="color:#808080;"><em>flip()
byteBuffer.flip();
System.<span style="color:#660e7a;"><strong><em>out</em></strong></span>.println(<span style="color:#008000;"><strong>"--------------allocate</strong></span><span style="color:#008000;font-family:'宋体';"><strong>切换为读取模式的变化</strong></span><span style="color:#008000;"><strong>---------------"</strong></span>);
System.<span style="color:#660e7a;"><strong><em>out</em></strong></span>.println(<span style="color:#008000;"><strong>"position:"</strong></span>+byteBuffer.position());
System.<span style="color:#660e7a;"><strong><em>out</em></strong></span>.println(<span style="color:#008000;"><strong>"limit:"</strong></span>+byteBuffer.limit());
System.<span style="color:#660e7a;"><strong><em>out</em></strong></span>.println(<span style="color:#008000;"><strong>"capacity:"</strong></span>+byteBuffer.capacity()); <span style="color:#808080;"><em>//4.</em></span><span style="color:#808080;font-family:'宋体';"><em>用</em></span><span style="color:#808080;"><em>get </em></span><span style="color:#808080;font-family:'宋体';"><em>读取数据
byte[] dst = new byte[byteBuffer.limit()];
byteBuffer.get(dst);
System.out.println(new String(dst,0,dst.length));
System.out.println("--------------allocate切换为读取时的变化get()---------------");
System.out.println("position:"+byteBuffer.position());
System.out.println("limit:"+byteBuffer.limit());
System.out.println("capacity:"+byteBuffer.capacity());<span style="color:#808080;"><em>//5.rewind()</em></span><span style="color:#808080;font-family:'宋体';"><em>可重复读数据
byteBuffer.rewind();
System.out.println("--------------allocate切换为读取时的变化rewind()---------------");
System.out.println("position:"+byteBuffer.position());
System.out.println("limit:"+byteBuffer.limit());
System.out.println("capacity:"+byteBuffer.capacity());<span style="color:#808080;"><em>//6.clear() </em></span><span style="color:#808080;font-family:'宋体';"><em>清空缓冲区 但是缓冲区中的数据依然存在</em></span><span style="color:#808080;"><em>,</em></span><span style="color:#808080;font-family:'宋体';"><em>只是处于</em></span><span style="color:#808080;"><em>"</em></span><span style="color:#808080;font-family:'宋体';"><em>被遗忘</em></span><span style="color:#808080;"><em>"</em></span><span style="color:#808080;font-family:'宋体';"><em>状态
byteBuffer.clear();
System.out.println("---------------clear() 清空缓冲区--------------");
System.out.println("position:"+byteBuffer.position());
System.out.println("limit:"+byteBuffer.limit());
System.out.println("capacity:"+byteBuffer.capacity());
//读取第一个字符时 依然可以读取到
System.out.println((char)byteBuffer.get());}
}
控制台输出:
--------------allocate初始化大小---------------
position:0
limit:1024
capacity:1024
--------------allocate存入数据后的变化---------------
position:11
limit:1024
capacity:1024
--------------allocate切换为读取模式的变化---------------
position:0
limit:11
capacity:1024
Hello world
--------------allocate切换为读取时的变化get()---------------
position:11
limit:11
capacity:1024
--------------allocate切换为读取时的变化rewind()---------------
position:0
limit:11
capacity:1024
---------------clear() 清空缓冲区--------------
position:0
limit:1024
capacity:1024
H
Java NIO的基本概念与使用的更多相关文章
- Java NIO通信的基础,基于TCP C/S例子介绍
为了更好的理解Netty异步事件驱动网络通信框架,有必要先了解一点Java NIO原生的通信理论,下面将结合基于TCP的例子程序,含客户端和服务端的源码,实现了Echo流程. Java NIO的核心概 ...
- Java NIO之Java中的IO分类
前言 前面两篇文章(Java NIO之理解I/O模型(一).Java NIO之理解I/O模型(二))介绍了,IO的机制,以及几种IO模型的内容,还有涉及到的设计模式.这次要写一些更贴近实际一些的内容了 ...
- Mina入门:Java NIO基础概念
JDK1.4引入了Java NIO API(Java New IO),Java NIO得到了广泛应用.NIO允许程序进行非阻塞IO操作.java.nio.* 包括以下NIO基本结构: Buffer - ...
- 支撑Java NIO 与 NodeJS的底层技术
支撑Java NIO 与 NodeJS的底层技术 众所周知在近几个版本的Java中增加了一些对Java NIO.NIO2的支持,与此同时NodeJS技术栈中最为人称道的优势之一就是其高性能IO,那么我 ...
- JAVA NIO学习笔记1 - 架构简介
最近项目中遇到不少NIO相关知识,之前对这块接触得较少,算是我的一个盲区,打算花点时间学习,简单做一点个人学习总结. 简介 NIO(New IO)是JDK1.4以后推出的全新IO API,相比传统IO ...
- Java NIO (转)
Java NIO提供了与标准IO不同的IO工作方式: Channels and Buffers(通道和缓冲区):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(B ...
- Java NIO使用及原理分析(1-4)(转)
转载的原文章也找不到!从以下博客中找到http://blog.csdn.net/wuxianglong/article/details/6604817 转载自:李会军•宁静致远 最近由于工作关系要做一 ...
- Java - NIO
java.nio:NIO-2: NIO 面向流的IO体系一次只能处理一个或多个字节/字符,直至读取所有字节/符,且流中的数据不能前后移动.效率低,当数据源中没有数据时会阻塞线程.Java-4提供的新A ...
- 【转】java NIO 相关知识
原文地址:http://www.iteye.com/magazines/132-Java-NIO Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的 ...
随机推荐
- Oracle 12C R2 on Linux 7.X Data Guard 搭建文档
1.查看主机和数据库信息 [oracle@oracle1 ~]$ sqlplus / as sysdba SQL*Plus: Release 12.2.0.1.0 Production on ...
- 查看网站使用何种框架或者技术的插件——Wappalyzer
Wappalyzer这款插件很强大,可以查看任何网站使用的技术,包括后端语言框架和前端语言框架.还有服务器是何种类型.甚至各种版本... 插件官网:https://wappalyzer.com/
- Mine Vison base on VC++ and procilica Gige Vison SDK
This is my first vision base on VC++6.0. I am so happy to record this time i succesfully create it b ...
- 新版本的AutoCAD2018 怎样删除 A360 Drive盘符
通常的做法,如下: (1)点击开始菜单的“运行”(Win+R或者Win+X快捷选择运行),在弹出的对话框输入“regedit”,回车,进入注册表编辑器. (2)找到HKEY_LOCAL_MACHINE ...
- 基于深度学习的目标检测(object detection)—— rcnn、fast-rcnn、faster-rcnn
模型和方法: 在深度学习求解目标检测问题之前的主流 detection 方法是,DPM(Deformable parts models), 度量与评价: mAP:mean Average Precis ...
- Altium Designer 在pcb下导入的原件引脚是绿的
当然也可能是其他规则原因导致的
- 【AtCoder Beginner Contest 074 A】Bichrome Cells
[链接]h在这里写链接 [题意] 在这里写题意 [题解] 在这里写题解 [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc++.h> using n ...
- docker安装及问题处理
1.在Ubuntu的命令行中输入 sudo apt-get install docker.io 2.如果切换到了root用户下 apt-get install docker.io 3.对于新安装的Ub ...
- 《JavaScript高级程序设计》笔记——第一章到第三章
2019年,新年伊始,我打算好好重读一下<JavaScript高级程序设计>这本前端必备经典书.每天半小时. 以下内容摘自<JavaScript高级程序设计> 2019-2-1 ...
- UIActionSheet上加入UIPickerView iOS8替换方案
此套替换方案採用"UIView+动画"方式实现(将UIActionSheet替换为UIView) 界面层级例如以下: 第一层:view(这一层充满整个屏幕,初始化时颜色为透明.us ...