博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java nio 概述
阅读量:7235 次
发布时间:2019-06-29

本文共 2269 字,大约阅读时间需要 7 分钟。

Java nio 概述

Java nio 全称Java new io是jdk1.4里提供的api。

Java nio 与 io最基本的差别

1、读写方式

Io是面向流的,仅仅能在一个方向上移动,一个输入流(inputStream)一个输出流(outputStream),须要从流中读一个或多个字节,直到读取全然部的字节。

Nio是面向缓冲的。能够双向,不管是读写,数据都会被先放到一个缓冲区

2.堵塞与非堵塞

Io流是堵塞的,当一个线程调用read()或write()时,直到被read或write完毕,在此期间。该线程处于等待堵塞模式,不干不论什么其它事情。

Nio 是非堵塞的。当一个线程从通道发出读/写的请求的时候,数据会被先放到缓冲区里。而不须要等待所有读写完毕,在此期间。这个线程能够去做别的事情,通常在空暇时候会运行其它通道上的io操作,一个线程能够管理多个通道

Nio核心概念:

Buffer (缓冲区),Channel(通道),Selector(选择器)

Buffer

前面已经提到,Nio是面向缓冲区的。全部的读写都要先放到缓冲区。

全部的缓冲区类型都继承于抽象类Buffer,最经常使用的是Bytebuffer, java基础类基本上都有相应的buffer类来一一相应。类继承关系图例如以下:

Channel

通道和io的流类似,主要差别为:通道是双向的,可读可写,io流是单向的。仅仅能读或写,并且操作通道不会直接从通道中写入或读取数据。都是由通道将数据放入缓冲区(buffer)中。

最经常使用的通道:
Filechannel 读取/写入 文件数据
Socketchannel TCP协议的socket 读写数据
Datagramchannel UDP协议读写数据
以下是客服端发送读或写的请求过程。

Filechannel 往文件里读取和写入数据的简单样例

读取文件内容:

public static void main(String[] args) {		FileInputStream fin = null;		try {			fin = new FileInputStream("c:\\nio.txt");		} catch (FileNotFoundException e) {			e.printStackTrace();		}		// 获取通道		FileChannel fc = fin.getChannel();		// 创建缓冲区		ByteBuffer buffer = ByteBuffer.allocate(1024);		// 读取数据到缓冲区		try {			fc.read(buffer);		} catch (IOException e) {			e.printStackTrace();		}		buffer.flip();		while (buffer.remaining() > 0) {			byte b = buffer.get();			System.out.print(((char) b));		}		try {			fin.close();		} catch (IOException e) {			e.printStackTrace();		}			}

写入文件内容:

public static void main(String[] args) {		File file = new File("c:\\nio.txt"); 		FileOutputStream outputStream = null;		try {			outputStream = new FileOutputStream(file);		} catch (FileNotFoundException e1) {			e1.printStackTrace();		} 		FileChannel channel = outputStream.getChannel(); 		ByteBuffer bufferWrite = ByteBuffer.allocate(1024); 		String string = "hello nio..."; 		bufferWrite.put(string.getBytes()); 		//这里必须调用flip(),先读取数据到Buffer。再从Buffer中读取数据。		bufferWrite.flip();		try {			channel.write(bufferWrite);			channel.close(); 			outputStream.close(); 		} catch (IOException e1) {			e1.printStackTrace();		} 	}
Select 
Select 能检測到注冊的全部通道上是否有读写请求,当有请求的时候才会进行读写,一个线程管理了多个通道。避免了多线程切换导致的开销。也不用去维护多个线程,操作原理例如以下图

这里介绍了javaio和nio的差别,以及nio的主要概念。还有简单的nio读写文件数据的样例,对nio就不做深入了。

有兴趣的同学能够看Jakob Jenkov的系列文章。http://tutorials.jenkov.com/java-nio/index.html

接下来会分享nio框架netty的一些学习心得,以及netty在实际项目架构中的使用

你可能感兴趣的文章
strcpy_s与strcpy的比較
查看>>
fscanf()函数具体解释
查看>>
JS魔法堂:关于元素位置和鼠标位置的属性
查看>>
jquery.validate+jquery.form提交的三种方式
查看>>
分形之树(Tree)
查看>>
[HTML/CSS]盒子模型,块级元素和行内元素
查看>>
HDU1698_Just a Hook(线段树/成段更新)
查看>>
学习selenium所须要具备的技术
查看>>
shell程序之逐行读取一文件里的參数且使用此參数每次运行5分钟
查看>>
高质量c c++编程
查看>>
[詹兴致矩阵论习题参考解答]习题4.1
查看>>
SQL Server 索引和表体系结构(非聚集索引)
查看>>
JS或AS中处理ARGB、RGBA颜色值时要小心
查看>>
【LeetCode】144. Binary Tree Preorder Traversal (3 solutions)
查看>>
English Metric Units and Open XML
查看>>
[ES6] 01. Intro to ES6 and traceur compiler
查看>>
专业版Unity技巧分享:使用定制资源配置文件
查看>>
【插件开发】—— 12 GEF入门
查看>>
solr集成mmseg4j分词
查看>>
less语法(一)变量与extend
查看>>