nio
1.I/O 输入输出流
(1) 指的是计算机与外界,或者程序与计算机之间数据交换的接口。
(2) 在java编程中,使用 流(Stream) 的方式完成I/O , 所有的I/O都被视为单个字节的移动。
通过一个Stream对象,一次移动一个字节。
Stream用于将字节转换为对象,或将对象转为字节。
(3)NIO和I/O有同样的作用和目的,但是它使用不同的方式,块 I/O
(4)NIO将最耗时的I/O操作(即最耗时的填充和读取缓冲区),转移回操作系统,因而可以极大地提高速度。
2.流与块的比较
(1) I/O和NIO最主要的区别的是数据打包和传输方式的不同。I/O以流的方式传输数据,NIO以块的方式传输数据
(2) 面向流
缺点:
流I/O一次一个字节(8 bit)读取数据。一个输入流产生一个字节数据,一个输出流消费一个字节的数
据,所以面向流的I/O相当慢。
优点:
为流式数据创建过滤器非常容易,链接几个过滤器,比如上面套一个Buffer缓存
(3) 面向块
一个面向块的I/O以块的形式处理数据。每一个操作都在一步中产生或消费一个数据块
优点:按块处理,比按字节处理效率要快的多
缺点:缺少流的优雅性和简单性
(4) 流的读取是单向的,而通道是双向的
3.通道和缓冲区
(1) 通道是原I/O中流的模拟,数据到任何地方都必须通过一个Channel对象来实现。
Channel是一个对象,可以通过它读取和写入数据,其作用类似于I/O中的Stream。程序读取数据时,先把数据从通道读入缓冲区,再从缓冲区读数据。
通道是双向的,而Stream是单向的,只在一个方向上移动(InputStream , OutputStream) ,而通道可以用于读、写,或者同时读写。
(2) 缓冲区实质上是一个容器对象,发送给一个通道的所有对象都必须首先放到缓冲区;同样的,从通道中读取任何数据都要读到缓冲区中。
Buffer是一个对象,它用于存放要写入或者刚读出的对象。在NIO中所有的数据都是用缓冲区处理的,当读取数据的时候,它是读取到缓冲区;
当写入数据的时候它是写入到缓冲区。
缓冲区实际是一个数组(通常是一个字节数组ByteBuffer,也可以是其它类型的),一个ByteBuffer可以在其底层字节上进行get/set操作。
4.Buffer内部细节
Buffer有3个属性描述其在任意时刻的状态,缓冲区Buffer其实是一个数组
(1) position
position变量跟踪已经读写了多少数据,比如一个缓冲区长度为10,往里写了3个字节,那其position值就是3,即第4个元素
如果从缓冲区往外读数据,即把数据写入Channel,如读了5个字节,position值为5,即第6个元素
(2) limit
limit表示当前缓冲区有多大容量能放入数据,或者当前缓冲区有多少数据等待被取出。
a.比如一个Buffer的长度是10,其limit就是10
b.当往里放5个元素时,position是5,其limit还是10,limit这时是不会变的
c.当从Buffer中往外取的时候,先调用buffer的flip()方法,其作用是,将limit值置为5,即当前position的值,position置为0
(3) capacity
capacity指定了缓冲区底层数组的容量,其值大小不会变。limit不会大于capacity
5.Buffer方法
(1) flip() , 将limit值置position的值,position置为0
(2) clear(),将limit置为和capacity相同,将position置为0,(相当于清空缓冲区,重新接收值)
(3) get() ,从Buffer读取数据
(3) put(),往Buffer写数据
6.直接缓冲区
(1) 直接缓冲区是一种为了加快I/O速度,而以一种特殊方式分配其内存的缓冲区。
给定一个直接字节缓冲区,Java虚拟机,将尽最大努力直接对它执行本机I/O操作,也就是说,jvm会在每一次调用底层操作系统的本机I/O操作
之前或之后,尝试避免将缓冲区的内容,拷贝到一个中间缓冲区中
看源码??
7.
nio的更多相关文章
- 源码分析netty服务器创建过程vs java nio服务器创建
1.Java NIO服务端创建 首先,我们通过一个时序图来看下如何创建一个NIO服务端并启动监听,接收多个客户端的连接,进行消息的异步读写. 示例代码(参考文献[2]): import java.io ...
- BIO\NIO\AIO记录
IO操作可以分为3类:同步阻塞(BIO).同步非阻塞(NIO).异步(AIO). 同步阻塞(BIO):在此种方式下,用户线程发起一个IO操作以后,必须等待IO操作的完成,只有当真正完成了IO操作以后, ...
- 支撑Java NIO 与 NodeJS的底层技术
支撑Java NIO 与 NodeJS的底层技术 众所周知在近几个版本的Java中增加了一些对Java NIO.NIO2的支持,与此同时NodeJS技术栈中最为人称道的优势之一就是其高性能IO,那么我 ...
- Java I/O and NIO [reproduced]
Java I/O and NIO.2---Five ways to maximize Java NIO and NIO.2---Build more responsive Java applicati ...
- JAVA NIO学习笔记1 - 架构简介
最近项目中遇到不少NIO相关知识,之前对这块接触得较少,算是我的一个盲区,打算花点时间学习,简单做一点个人学习总结. 简介 NIO(New IO)是JDK1.4以后推出的全新IO API,相比传统IO ...
- Java NIO概述
Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然 Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Se ...
- JAVA NIO Socket通道
DatagramChannel和SocketChannel都实现定义读写功能,ServerSocketChannel不实现,只负责监听传入的连接,并建立新的SocketChannel,本身不传输数 ...
- JAVA NIO FileChannel 内存映射文件
文件通道总是阻塞式的. 文件通道不能创建,只能通过(RandomAccessFile.FileInputStream.FileOutputStream)getChannel()获得,具有与File ...
- java nio系列文章
java nio系列教程 基于NIO的Client/Server程序实践 (推荐) java nio与并发编程相关电子书籍 (访问密码 48dd) 理解NIO nio学习记录 图解ByteBuff ...
- (转)NIO与AIO,同步/异步,阻塞/非阻塞
原文地址: http://www.cnblogs.com/enjoy-ourselves/p/3793771.html 1.flip(),compact(),与clear()的使用 flip()内部实 ...
随机推荐
- Servlet编程
Servlet编程 1. servlet概念及相关接口简介 java Servlet是运行在web服务器或应用服务器上的程序,他是作为来自web浏览器或其他HTTP客户端的请求和HTTP服务器山的数据 ...
- Hangfire入门(任务调度)
一.简介 英文官网:http://hangfire.io/ 开源地址:https://github.com/HangfireIO Hangfire 不依赖于具体的.NET应用类型,包含.NET 和.N ...
- 解读ASP.NET 5 & MVC6系列(16):自定义View视图文件查找逻辑
之前MVC5和之前的版本中,我们要想对View文件的路径进行控制的话,则必须要对IViewEngine接口的FindPartialView或FindView方法进行重写,所有的视图引擎都继承于该IVi ...
- [LeetCode] Ugly Number II 丑陋数之二
Write a program to find the n-th ugly number. Ugly numbers are positive numbers whose prime factors ...
- [LeetCode] Minimum Size Subarray Sum 最短子数组之和
Given an array of n positive integers and a positive integer s, find the minimal length of a subarra ...
- IT培训行业揭秘(五)
前面说了一大堆,简单揭露了一些目前培训行业鱼龙混在的情况,那么今天我就站在一个即将毕业的大学生角度来谈谈如何选择一个靠谱的培训机构. 你即将大学毕业了,在大学里面浑浑噩噩的混了几年,马上就要离开校园, ...
- docker 常用命令(*)
查找镜像 https://hub.docker.com/ search --> centos7 一般docker 会有一个基础镜像,中间件镜像,应用镜像,生成一个镜像 docker build ...
- 语义网 (Semantic Web)和 web 3.0
语义网=有意义的网络. "如果说 HTML 和 WEB 将整个在线文档变成了一本巨大的书,那么 RDF, schema, 和 inference languages 将会使世界上所有的数据变 ...
- swfit-学习笔记(数组的使用)
Swift数组的使用,参考:<The Swift Programming Language>中文版 // Copyright (c) 2015年 Zsmile. All rights re ...
- 使用ARP欺骗, 截取局域网中任意一台机器的网页请求,破解用户名密码等信息
ARP欺骗的作用 当你在网吧玩,发现有人玩LOL大吵大闹, 用ARP欺骗把他踢下线吧 当你在咖啡厅看上某一个看书的妹纸,又不好意思开口要微信号, 用arp欺骗,不知不觉获取到她的微信号和聊天记录,吓一 ...