JavaNIO
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的更多相关文章
- javaNIO(转载)
(一) Java NIO 概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Chan ...
- JAVANIO通道
package com.nio.test; import java.io.FileInputStream; import java.io.FileNotFoundException; import j ...
- javaNIO核心概念
在java的阻塞IO中使用InputStream和outputStream来进行输入和输出,那么两种流是相互独立使用的,而且每次数据传输都要通过“用户态数据”向“os内核态数据”copy或从“os内核 ...
- javaNIO学习
Buffer其实就是是一个容器对象,它包含一些要写入或者刚读出的数据.在NIO中加入Buffer对象,体现了新库与原I/O的一个重要区别.在面向流的I/O中,您将数据直接写入或者将数据直接读到Stre ...
- javaNIO是什么?由那几部分组成?各部分的作用。
Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Sel ...
- JavaIO和JavaNIO
BIO和NIO BIO在之前的服务器处理模型中,在调用ServerSocket.accept()方法时,会一直阻塞到有客户端连接才会返回,每个客户端连接过来后,服务端都会accept一个新连接,接着启 ...
- JavaNIO之Channel
Channel的本质是通道,用来连接JVM之外数据向JVM内传输数据,比如来自于硬盘的文件,来自于网络的数据包.JVM之外的数据就是通过Channel进行数据传输:如果把Channel比作河道,那么作 ...
- (基础篇 走进javaNIO)第二章-NIO入门
在本章巾,我们会分别对 JDK 的BIO ,NIO 和JDK 1.7 最新提供的 NI02.0的使用进行详细说明 ,通过流程图和代 码讲解,让大 家体会到随着 Ja va 1/0 类库的 不断发展和改 ...
- (基础篇 走进javaNIO)第一章-java的i/o演进之路
Java 是由 SUN公司在 1995 年首先发布 的编程语 言和计算平 台.这基础技术 支持最新 的程序 ,包括 实用程序 .游 戏和业 务应用程序 .J ava 在世界各地 的 8.5 亿 多 ...
- JavaNIO深入学习
NIO是Jdk中非常重要的一个组成部分,基于它的Netty开源框架可以很方便的开发高性能.高可靠性的网络服务器和客户端程序.本文将就其核心基础类型Channel, Buffer, Selector进行 ...
随机推荐
- spark MLlib 概念 4: 协同过滤(CF)
1. 定义 协同过滤(Collaborative Filtering)有狭义和广义两种意义: 广义协同过滤:对来源不同的数据,根据他们的共同点做过滤处理. Collaborative filterin ...
- linux的awk使用
awk统计password文件中,登陆shell为“/sbin/nologin”的用户个数 [root@localhost ~]# cat passwd | grep "/sbin/nolo ...
- no CUDA-capable device is detected,或者GPU is lost
出现以下问题,程序只能运行一次,而且每运行一次显卡就不见了,出现以下情况,只能重启才可以再次检测到: 最后解决: 我本来安装的是cuda9.0 但是(下面显示是10): 起初是因为说他表示最高可以到 ...
- UTF-8 有BOM 和 无BOM的区别
BOM: Byte Order Mark,即字节序标志 在UCS 编码中有一个叫做"ZERO WIDTH NO-BREAK SPACE"的字符,它的编码是FEFF.而FFFE在UC ...
- ffmpeg 视频过度滤镜 gltransition
ffmpeg 视频过度滤镜 gltransition 上次随笔中提到的 ffmpeg-concat 可以处理视频过度,但是缺点是临时文件超大. 经过查找 ffmpeg 还有 gltransition ...
- 简单的servlet下载
<servlet> <servlet-name>servletTest</servlet-name> <servlet-class>com.shangs ...
- oracle 在sql中显示blob的字符串
最近在用oracle的过程中用到了对blob字段模糊查询的问题,对oracle来说,我并不是高手,找了很多的资料终于能够查出来了. blob字段直接用 select * from table_name ...
- Swift 发送邮件和附件
public function send($filename, array $render = [],$subject = '审核通知') { // Create the Transport $tra ...
- eureka和zookeeper的区别?
eureka和zookeeper都可以提供服务注册与发现的功能, zookeeper 是CP原则,强一致性(consistency)和分区容错性(Partition). eur ...
- Java中File类的基本用法
File类的基本用法 java.io.File类:代表文件和目录.在开发中,读取文件.生成文件.删除文件.修改文件的属性时经常会用到此类. File类的常用构造方法:public File(Strin ...