NIO专题:http://developer.51cto.com/art/201112/307172.htm

一、新IO概述:

新IO和传统IO都是用于进行输入/输出,相比于传统IO面向流的处理方式,新IO采用内存映射文件来处理输入/输出,新IO将文件或文件的一段区域映射到内存中,这样就可以像访问内存一样来访问文件了,所以这种访问方式既方便又快得多。

新IO中的两个核心对象:Channel(通道)和Buffer(缓冲)。Channel用于新IO的数据传输,相对于传统IO中的InputStream和OutputStream,Channel提供了一个map()方法用来将一段数据映射成为一块内存。也就是在新IO中,改变了传统IO面向流的处理而转向面向块的处理方式。

Buffer是一个容器,它的本质是一个数组。发送到Channel的所有对象以及从Channel取出的所有数据先存放到Buffer中。

除了上面两个核心对象外,新IO还提供了Charset类用于将Unicode字符串映射成字节序列以及逆映射操作。以及Selector类用于支持非阻塞式输入输出。

二、Java中与新IO相关的包:

1.java.nio包:主要包含各种与Buffer相关的类

2.java.nio.channels包:主要包含与Channel和Selector相关的类

3.java.nio.charset包:主要包含与字符集相关的类

4.java.nio.channels.spi包:主要包含与Channel相关的服务提供者编程接口。

5.java.nio.charset.spi包:包含与字符集相关的服务提供者编程接口

三、Channel介绍以及使用

Channel可以直接将指定文件的部分或全部直接映射成Buffer,并且程序不能直接访问Channel中的数据,Channel只能与Buffer交互。

Channel接口提供了DatagramChannel、FIleChannel、SocketChannel、ServerSocketChannel等实现类。由此可见Channel是按功能进行了划分。

Channel所有的对象都不是通过构造器创建的,而是通过传统节点InputStream和OutputStream的getChannel()方法获得的。但是不同的节点获得的Channel对象也不同,是各自节点类型对应的Channel对象。例如:FileInputStream通过getChannel获得的Channel对象是FileChannel对象。

虽然Channel对象既可以读取也可以写入,但是InputStream获得的Channel只能读,OutputStream获得Channel对象只能写。

Channel中常用的方法:map()、read()、write(),read()和write()方法有一系列的重载形式,这些方法用于从Buffer中读或写数据。

四、Buffer的介绍及使用

Buffer可以保存多个类型相同的数据。Buffer是一个抽象类,最常用的子类是ByteBuffer,它可以在底层字节数组上进行get/set操作。另外还有其他的子类:CharBuffer、ShortBuffer、IntBuffer等。

Buffer中有三个重要的概念:容量(capacity)、界限(limit)、和位置(position)。

容量:缓冲区的容量,即最多可以存储多少数据,其中缓冲区的容量不可以为负数,创建后不容许改变。

界限:第一个不应该被读出或者写入的缓冲区位置索引,也就是以此为界限后面的区域无法读写数据。

位置:指明下一个可以被读出或者写入的缓冲区位置索引。

put()方法和get()用于放入、取出数据。

flip()方法,调用该方法后界限就回到原来的position所在位置。

clear()方法,将position设置为0。将limit设为与capacity相等。

五、字符集和Charset

所有的文件底层都是二进制文件,即全部都是字节码。把明文的字符转换成二进制序列称为编码,把二进制编码转换成明文字符串称为解码。JDK1.4之后提供了Charset类来处理字节序列和字符序列之间的转换关系,该类中包含用于解码和编码的方法。其中该类提供的availableCharset()方法来获取当前JDK所支持的所有字符集。

NIO概览的更多相关文章

  1. Netty网络编程之NIO概览与简单应用

    >>关于NIO Java NIO即Java Non-blocking IO(Java非阻塞I/O),是Jdk1.4之后增加的一套操作I/O工具包,又被叫做Java New IO. (1)R ...

  2. Java NIO 概览

    Java面试通关手册(Java学习指南) Github地址:https://github.com/Snailclimb/Java_Guide 一 NIO简介 Java NIO 是 java 1.4 之 ...

  3. 传统IO与NIO的比较

    本文并非Java.io或Java.nio的使用手册,也不是如何使用Java.io与Java.nio的技术文档.这里只是尝试比较这两个包,用最简单的方式突出它们的区别和各自的特性.Java.nio提出了 ...

  4. Java NIO之Selector(选择器)

    历史回顾: Java NIO 概览 Java NIO 之 Buffer(缓冲区) Java NIO 之 Channel(通道) 其他高赞文章: 面试中关于Redis的问题看这篇就够了 一文轻松搞懂re ...

  5. java 的nio与io对比

    转:本文并非Java.io或Java.nio的使用手册,也不是如何使用Java.io与Java.nio的技术文档.这里只是尝试比较这两个包,用最简单的方式突出它们的区别和各自的特性.Java.nio提 ...

  6. 关于Java IO与NIO知识都在这里

    由于内容比较多,我下面放的一部分是我更新在我的微信公众号上的链接,微信排版比较好看,更加利于阅读.每一篇文章下面我都把文章的主要内容给列出来了,便于大家学习与回顾. Java面试通关手册(Java学习 ...

  7. Java NIO之拥抱Path和Files

    Java面试通关手册(Java学习指南)github地址(欢迎star和pull):https://github.com/Snailclimb/Java_Guide 历史回顾: Java NIO 概览 ...

  8. Java NIO 之 Channel(通道)

    历史回顾: Java NIO 概览 Java NIO 之 Buffer(缓冲区) 其他高赞文章: 面试中关于Redis的问题看这篇就够了 一文轻松搞懂redis集群原理及搭建与使用 一 Channel ...

  9. Java NIO文章列表(强烈推荐 转)

    IO流学习总结 一 Java IO,硬骨头也能变软 二 java IO体系的学习总结 三 Java IO面试题 NIO与AIO学习总结 一 Java NIO 概览 二 Java NIO 之 Buffe ...

随机推荐

  1. Unity和安卓互调

    Unity调安卓 AndroidJavaClass jc = new AndroidJavaClass("com.unity3d.player.UnityPlayer"); And ...

  2. 各种波形文件vcd,vpd,shm,fsdb生成的方法(zz)

    仿真是IC设计不可或缺的重要步骤,仿真后一般需要记录下波形文件,用于做详细分析和研究.说一下几种波形文件WLF(Wave Log File).VCD(Value Change Dump)文件,fsdb ...

  3. cygwin 运行java的一些记录

    javac编译没问题,但是java执行就不行,处理方式如下 其实就是把宿主机下的java.exe在cygwin下搞一个快捷方式 关于路径问题,可以使用cygpath命令进行宿主机和cygwin间的转换 ...

  4. 页面跳转时候拼接在url后面的多个 参数获取

    function GetRequest() { var url = location.search; var theRequest = new Object(); if (url.indexOf(&q ...

  5. SAP安装前添加虚拟网卡步骤

    添加虚拟网卡: 打开控制面版中的设备管理器 点击菜单栏上的[操作(A)] 选择[添加过时硬盘件] 选择[ 安装我手动从列表选择的硬件(高级)(M) ],点击[下一步] 选择[网络适配器],点击[下一步 ...

  6. 阿里云高速maven库

    <repository> <id>alimaven</id> <name>aliyun maven</name> <url>ht ...

  7. AndroidStudio添加Android源码

    找了半天没找到,还是用google好啊!修改如下,打开如下的build.gradle,修改compileSdkVersion 为你下载的源码版本号. Open your sdk manager fro ...

  8. RP2837 IN1-IN2 对应关系 2路DI

    RP2837 IN1-IN2 对应关系: IN1   ARM-IO2   PA16 IN2   ARM-IO6   PA4 root@sama5d3-linux:~ echo 16  > /sy ...

  9. NameNode机制和DataNode机制

    首先我们看一下NAMENODE: 我们已经知道了NAMENODE作为DATANODE的管理者,其重要性不言而喻,那么NAMENODE是怎么管理数据的呢? 首先,我们看一下上面这张图,每次客户端读写数据 ...

  10. 记一次redis攻击

    服务器挖矿病毒的排查过程 事情起因:朋友的一台阿里云主机,登录特别卡,找我看看 这一看就感觉出问题了,机器特别卡,top看了一眼,cpu几乎是100%运行 但是奇怪的是用top命令完全看不出来哪个进程 ...