Java New IO 简称 nio,在jdk1.4提供了新的api,有如下特性:

1.为所有原始类型提供缓存支持

2.字符集编解码解决方案

3.Channel:新的原始io抽象

4.支持锁和内存映射的访问接口

5.提供多路(non-bloking)非阻塞式多路高伸缩性网络io

nio的两个创新:

缓冲区

通道

原始io与nio比较:

1.原始java.io.*包库与nio最重要的区别是数据打包和传输方式,io中使用流的方式处理数据,nio中使用块的方式处理数据。

流:流方式处理数据是输入一个字节,输出一个字节。处理比较慢

块:块的方式处理数据每步操作产生或者消费一个数据块,处理速度快。

数据缓冲区:

找了个博客,里面有比较详细的介绍,就不写了http://www.cnblogs.com/chenpi/p/6475510.html

api测试:

package com.gengsc.buffer;

import java.nio.IntBuffer;
import java.util.Arrays; import javax.swing.ButtonGroup; /**
* @author shichaogeng
*
* 2017年7月12日
*/
public class BufferTest { public static void main(String[] args) { //创建指定长度的缓冲区
IntBuffer buffer = IntBuffer.allocate(); //使用数组创建缓冲区数组
int[] arr = {, , };
//未修改缓冲区之前的数组
System.out.println("未修改缓冲区之前的数组: ");
System.out.println(Arrays.toString(arr));
buffer = buffer.wrap(arr); //使用offset
buffer = buffer.wrap(arr, , ); //修改元素位置
buffer.put(, ); //遍历缓冲区数组
System.out.println("缓冲区数组如下: ");
for (int i = ; i < buffer.limit(); i++) {
System.out.println(buffer.get());
} System.out.println("原始数据: ");
System.out.println(Arrays.toString(arr)); buffer.clear();
buffer.flip();
System.out.println(buffer); System.out.println(buffer.duplicate());
}
}

通道:

通道(channel)用于字节缓冲区与通道另一侧实体(文件或者套接字)有效的传输数据。

两种通道:

File通道 FileChannel

  FileChanel只能通过file对象调用getChannel获取

Scoket通道 SocketChannel SocketServerChannel DatagramChannel

通道分为单向(unidirectionnal)和双向(bidirectional)的

实现WritableByteChannel的write方法和实现ReadableByteChannel的read方法,那么它是一个单向通道。

同时实现上述两个接口的类就是双向通道。

通道的阻塞和非阻塞:

非阻塞模式(no-blocking)永远不会让调用的线程休眠。请求操作要么立即返回,要么返回结果表明未进行操作。只有面向流的通道,sockets和pipes才使用非阻塞通道。

JavaNIO的更多相关文章

  1. javaNIO(转载)

    (一) Java NIO 概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Chan ...

  2. JAVANIO通道

    package com.nio.test; import java.io.FileInputStream; import java.io.FileNotFoundException; import j ...

  3. javaNIO核心概念

    在java的阻塞IO中使用InputStream和outputStream来进行输入和输出,那么两种流是相互独立使用的,而且每次数据传输都要通过“用户态数据”向“os内核态数据”copy或从“os内核 ...

  4. javaNIO学习

    Buffer其实就是是一个容器对象,它包含一些要写入或者刚读出的数据.在NIO中加入Buffer对象,体现了新库与原I/O的一个重要区别.在面向流的I/O中,您将数据直接写入或者将数据直接读到Stre ...

  5. javaNIO是什么?由那几部分组成?各部分的作用。

    Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Sel ...

  6. JavaIO和JavaNIO

    BIO和NIO BIO在之前的服务器处理模型中,在调用ServerSocket.accept()方法时,会一直阻塞到有客户端连接才会返回,每个客户端连接过来后,服务端都会accept一个新连接,接着启 ...

  7. JavaNIO之Channel

    Channel的本质是通道,用来连接JVM之外数据向JVM内传输数据,比如来自于硬盘的文件,来自于网络的数据包.JVM之外的数据就是通过Channel进行数据传输:如果把Channel比作河道,那么作 ...

  8. (基础篇 走进javaNIO)第二章-NIO入门

    在本章巾,我们会分别对 JDK 的BIO ,NIO 和JDK 1.7 最新提供的 NI02.0的使用进行详细说明 ,通过流程图和代 码讲解,让大 家体会到随着 Ja va 1/0 类库的 不断发展和改 ...

  9. (基础篇 走进javaNIO)第一章-java的i/o演进之路

    Java 是由 SUN公司在 1995 年首先发布 的编程语 言和计算平 台.这基础技术 支持最新 的程序 ,包括 实用程序 .游 戏和业 务应用程序 .J ava 在世界各地 的 8.5  亿 多 ...

  10. JavaNIO深入学习

    NIO是Jdk中非常重要的一个组成部分,基于它的Netty开源框架可以很方便的开发高性能.高可靠性的网络服务器和客户端程序.本文将就其核心基础类型Channel, Buffer, Selector进行 ...

随机推荐

  1. spark MLlib 概念 4: 协同过滤(CF)

    1. 定义 协同过滤(Collaborative Filtering)有狭义和广义两种意义: 广义协同过滤:对来源不同的数据,根据他们的共同点做过滤处理. Collaborative filterin ...

  2. linux的awk使用

    awk统计password文件中,登陆shell为“/sbin/nologin”的用户个数 [root@localhost ~]# cat passwd | grep "/sbin/nolo ...

  3. no CUDA-capable device is detected,或者GPU is lost

    出现以下问题,程序只能运行一次,而且每运行一次显卡就不见了,出现以下情况,只能重启才可以再次检测到: 最后解决: 我本来安装的是cuda9.0 但是(下面显示是10):  起初是因为说他表示最高可以到 ...

  4. UTF-8 有BOM 和 无BOM的区别

    BOM: Byte Order Mark,即字节序标志 在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF.而FFFE在UC ...

  5. ffmpeg 视频过度滤镜 gltransition

    ffmpeg 视频过度滤镜 gltransition 上次随笔中提到的 ffmpeg-concat 可以处理视频过度,但是缺点是临时文件超大. 经过查找 ffmpeg 还有 gltransition ...

  6. 简单的servlet下载

    <servlet> <servlet-name>servletTest</servlet-name> <servlet-class>com.shangs ...

  7. oracle 在sql中显示blob的字符串

    最近在用oracle的过程中用到了对blob字段模糊查询的问题,对oracle来说,我并不是高手,找了很多的资料终于能够查出来了. blob字段直接用 select * from table_name ...

  8. Swift 发送邮件和附件

    public function send($filename, array $render = [],$subject = '审核通知') { // Create the Transport $tra ...

  9. eureka和zookeeper的区别?

    eureka和zookeeper都可以提供服务注册与发现的功能,       zookeeper 是CP原则,强一致性(consistency)和分区容错性(Partition).       eur ...

  10. Java中File类的基本用法

    File类的基本用法 java.io.File类:代表文件和目录.在开发中,读取文件.生成文件.删除文件.修改文件的属性时经常会用到此类. File类的常用构造方法:public File(Strin ...