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的基本概念与使用的更多相关文章

  1. Java NIO通信的基础,基于TCP C/S例子介绍

    为了更好的理解Netty异步事件驱动网络通信框架,有必要先了解一点Java NIO原生的通信理论,下面将结合基于TCP的例子程序,含客户端和服务端的源码,实现了Echo流程. Java NIO的核心概 ...

  2. Java NIO之Java中的IO分类

    前言 前面两篇文章(Java NIO之理解I/O模型(一).Java NIO之理解I/O模型(二))介绍了,IO的机制,以及几种IO模型的内容,还有涉及到的设计模式.这次要写一些更贴近实际一些的内容了 ...

  3. Mina入门:Java NIO基础概念

    JDK1.4引入了Java NIO API(Java New IO),Java NIO得到了广泛应用.NIO允许程序进行非阻塞IO操作.java.nio.* 包括以下NIO基本结构: Buffer - ...

  4. 支撑Java NIO 与 NodeJS的底层技术

    支撑Java NIO 与 NodeJS的底层技术 众所周知在近几个版本的Java中增加了一些对Java NIO.NIO2的支持,与此同时NodeJS技术栈中最为人称道的优势之一就是其高性能IO,那么我 ...

  5. JAVA NIO学习笔记1 - 架构简介

    最近项目中遇到不少NIO相关知识,之前对这块接触得较少,算是我的一个盲区,打算花点时间学习,简单做一点个人学习总结. 简介 NIO(New IO)是JDK1.4以后推出的全新IO API,相比传统IO ...

  6. Java NIO (转)

    Java NIO提供了与标准IO不同的IO工作方式: Channels and Buffers(通道和缓冲区):标准的IO基于字节流和字符流进行操作的,而NIO是基于通道(Channel)和缓冲区(B ...

  7. Java NIO使用及原理分析(1-4)(转)

    转载的原文章也找不到!从以下博客中找到http://blog.csdn.net/wuxianglong/article/details/6604817 转载自:李会军•宁静致远 最近由于工作关系要做一 ...

  8. Java - NIO

    java.nio:NIO-2: NIO 面向流的IO体系一次只能处理一个或多个字节/字符,直至读取所有字节/符,且流中的数据不能前后移动.效率低,当数据源中没有数据时会阻塞线程.Java-4提供的新A ...

  9. 【转】java NIO 相关知识

    原文地址:http://www.iteye.com/magazines/132-Java-NIO Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的 ...

随机推荐

  1. 简约之美jodd--props属性使用

    Prop是一个超级properties:包含了很多jdk缺失的东西:utf-8支持,宏,分区,profiles,全配置等等. 属性存储在一个或者多个*.props文件,而且它是开放的,支持多种类型的资 ...

  2. 洛谷P3954 成绩【民间数据】

    题目背景 数据已修复 题目描述 牛牛最近学习了C++入门课程,这门课程的总成绩计算方法是: 总成绩=作业成绩×20%+小测成绩×30%+期末考试成绩×50% 牛牛想知道,这门课程自己最终能得到多少分. ...

  3. Monkey测试执行指导

    1.Monkey常规测试

  4. 关于Django的登录系统

    首先需要明确的是登录的本质:登录就是服务器确认当前用户的身份,并将数据库中的记录提取匹配 默认的登录系统是用户名密码方式,这种方式很平常,也没什么特别的.这里主要说的是第三方验证登录 通常第三方验证登 ...

  5. 【Educational Codeforces Round 35 D】Inversion Counting

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 排列中交换任意两个数字. 排列的逆序对个数的奇偶性会发生变化. 翻转这个过程其实就是len/2对数字发生交换. 交换了偶数次的话,不 ...

  6. ontouch、dispatchtouchevent、interceptouchevent-相关事件

    这几天一直在研究onTouch的相关方法,今天我们就来看看onTouchEvent.dispatchTouchEvent.onIntercepTouchEvent这三个方法在控件之间的传递顺序 pub ...

  7. poj 1191 棋盘切割 (压缩dp+记忆化搜索)

    一,题意: 中文题 二.分析: 主要利用压缩dp与记忆化搜索思想 三,代码: #include <iostream> #include <stdio.h> #include & ...

  8. Android Warning not all local changes may be shown due to an error

    idea使用svn出现Warning not all local changes may be shown due to an error,如下图所示: 解决方案: 1.File > Setti ...

  9. 宏的使用 extern

    声明全局变量使用的技术. 有些时候C语言的一些条条框框就像语法.学会C语言就是学会了语法. 但是语法怎样使用就又是另一回事了. 我希望自己能多学习一些技巧,而不是一些固定的C语言语法. 这篇文章真的很 ...

  10. 手机用appnium,web自动化用eclips+webdriver2

    手机用appnium,web自动化用eclips+webdriver2 吴建清 pycharm 1.安装环境2.pycharm类似eclipse,写脚本,运行脚本3.uiautomatorviewer ...