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的更多相关文章

  1. 源码分析netty服务器创建过程vs java nio服务器创建

    1.Java NIO服务端创建 首先,我们通过一个时序图来看下如何创建一个NIO服务端并启动监听,接收多个客户端的连接,进行消息的异步读写. 示例代码(参考文献[2]): import java.io ...

  2. BIO\NIO\AIO记录

    IO操作可以分为3类:同步阻塞(BIO).同步非阻塞(NIO).异步(AIO). 同步阻塞(BIO):在此种方式下,用户线程发起一个IO操作以后,必须等待IO操作的完成,只有当真正完成了IO操作以后, ...

  3. 支撑Java NIO 与 NodeJS的底层技术

    支撑Java NIO 与 NodeJS的底层技术 众所周知在近几个版本的Java中增加了一些对Java NIO.NIO2的支持,与此同时NodeJS技术栈中最为人称道的优势之一就是其高性能IO,那么我 ...

  4. 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 ...

  5. JAVA NIO学习笔记1 - 架构简介

    最近项目中遇到不少NIO相关知识,之前对这块接触得较少,算是我的一个盲区,打算花点时间学习,简单做一点个人学习总结. 简介 NIO(New IO)是JDK1.4以后推出的全新IO API,相比传统IO ...

  6. Java NIO概述

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

  7. JAVA NIO Socket通道

      DatagramChannel和SocketChannel都实现定义读写功能,ServerSocketChannel不实现,只负责监听传入的连接,并建立新的SocketChannel,本身不传输数 ...

  8. JAVA NIO FileChannel 内存映射文件

      文件通道总是阻塞式的. 文件通道不能创建,只能通过(RandomAccessFile.FileInputStream.FileOutputStream)getChannel()获得,具有与File ...

  9. java nio系列文章

    java nio系列教程 基于NIO的Client/Server程序实践 (推荐) java nio与并发编程相关电子书籍   (访问密码 48dd) 理解NIO nio学习记录 图解ByteBuff ...

  10. (转)NIO与AIO,同步/异步,阻塞/非阻塞

    原文地址: http://www.cnblogs.com/enjoy-ourselves/p/3793771.html 1.flip(),compact(),与clear()的使用 flip()内部实 ...

随机推荐

  1. Spring事物管理

    spring事务配置的五种方式 前段时间对Spring的事务配置做了比较深入的研究,在此之间对Spring的事务配置虽说也配置过,但是一直没有一个清楚的认识.通过这次的学习发觉Spring的事务配置只 ...

  2. HDU 1564 Play a game(巴什博弈)

    New Year is Coming! ailyanlu is very happy today! and he is playing a chessboard game with 8600. The ...

  3. 直播推流之blibli和拉流LFLiveKit

    执行上面操作后,导入合成的拉流blibli包到工程中,然后新建个播放控制器来设置播放 1.  播放的一些操作. 2. 高斯模糊. 3. 新建聊天控制器. - (void)viewDidLoad { [ ...

  4. 解决 node-gyp command not found 的问题

    node-gyp明明已经安装了,但是不能执行,显示命令找不到,然后重装之,发现npm有一个提示信息: npm WARN prefer global node-gyp@3.4.0 should be i ...

  5. Linux下Source Insight的安装和汉化

    原创文章,转载请注明出处. 工欲善其事,必先利其器.Source Insight绝对是阅读C和C++代码的利器,另外,Source Insight的体量很小,安装便捷,显示直观,比vim+cscope ...

  6. [LeetCode] Remove K Digits 去掉K位数字

    Given a non-negative integer num represented as a string, remove k digits from the number so that th ...

  7. [LeetCode] Merge Intervals 合并区间

    Given a collection of intervals, merge all overlapping intervals. For example, Given [1,3],[2,6],[8, ...

  8. [LeetCode] Divide Two Integers 两数相除

    Divide two integers without using multiplication, division and mod operator. If it is overflow, retu ...

  9. ping环回地址和ping主机地址的区别

    ping127.0.0.1和ping本机的过程是不一样的ip输出函数先检查地址是不是环回地址1.如果是环回地址 直接交给环回驱动程序处理 返回ip输入函数2.如果不是环回地址 检查是不是广播或者多播地 ...

  10. git 指令

    單獨看這個 commit id 做了什麼修改 git show CommitID or git diff CommitID^!