nio笔记】的更多相关文章

一.Java IO 和 系统 IO 不匹配 在大多数情况下,Java 应用程序并非真的受着 I/O 的束缚.操作系统并非不能快速传送数据,让 Java 有事可做:相反,是 JVM 自身在 I/O 方面效率欠佳.操作系统与 Java 基于流的 I/O模型有些不匹配.操作系统要移动的是大块数据(缓冲区),这往往是在硬件直接存储器存取(DMA)的协助下完成的.而 JVM 的 I/O 操作类喜欢操作小块数据——单个字节.几行文本.结果,操作系统送来整缓冲区的数据,java.io 包的流数据类再花大量时间…
网上的很多关于NIO的资料是不正确的,nio 支持阻塞和非阻塞模式 关于读写状态切换 在读写状态切换的情况下是不能使用regedit 方法注册,而应该使用以下方式进行 selectionKey.interestOps(SelectionKey.OP_READ|SelectionKey.OP_WRITE); setsoTimeout 只是说明允许连接阻塞时间,而不是连接持续时间. select(timeOut) 表示选择器阻塞时间,超过该事件关闭全部的channal serverSocketCha…
小弟前端时间由于开发个管理系统导致断更了近20天!!马上就要春招了,学习了一下NIO,将笔记记录下,希望和我一样的18届毕业生都能找到满意的公司!! 本文记录了NIO与IO的区别,缓冲区的数据存取,直接缓冲区与非直接缓冲区,通道的原理与获取,通道之间的数据传输 一.简介 1.NIO简介:  与原来的IO有同样的作用与目的,但是使用的方式完全不同,NIO支持面向缓冲区的,基于通道的IO操作. 2.NIO与IO主要区别: IO: (1)面向流 (单向的,一个 输入,一个输出,InputStream,…
1. Channel Channel接口只提供了两个方法: package java.nio.channels; public interface Channel { public boolean isOpen( ); public void close( ) throws IOException;} 调用close()可能会造成阻塞,如果同一个Channel上多次调用close()也没有什么问题,如果第一次调用阻塞了,后续的调用都会阻塞,知道第一次调用关闭, 此时,后续的调用将不执行任何操作,…
缓冲区操作:缓冲区,以及缓冲区如何工作,是所有I/O的基础.所谓“输入/输出”讲的无非就是把数据移出货移进缓冲区.进程执行I/O操作,归纳起来也就是向操作系统发出请求,让它要么把缓冲区里的数据排干,要么用数据把缓冲区填满.进程使用这一机制处理所有数据进出操作.Java.nio中的类被特意的设计为支持级联调用.Java NIO:Java NIO是一个可以替代标准Java IO API的IO API,Java NIO提供了与标准IO不同的IO工作方式.Java NIO:Channels and Bu…
http://blog.csdn.net/z69183787/article/category/2191483此人的博客 首先你要知道阻塞和非阻塞的概念,阻塞体现在这个线程不能干别的了,只能在这里等着.非阻塞体现在这个线程可以去干别的,不需要一直在这等着.说NIO的非阻塞原理之前,我们需要先说一下传统的io.传统的IO是按字节传输的,即每次传输一个字节.为了提高数据传输效率,引进了带缓冲区得输入输出模式,这样每次就可以传输大量的字节数, 但是,会导致在读(写)缓冲区没有满的情况下,程序会一直等待…
Java NIO即Java Non-blocking IO(Java非堵塞I/O),由于是在Jdk1.4之后添加的一套新的操作I/O工具包,所以通常会被叫做Java New IO.NIO是为提供I/O吞吐量而专门设计.其卓越的性能甚至能够与C媲美. NIO是通过Reactor模式的事件驱动机制来达到Non blocking的,那么什么是Reactor模式呢?Reactor翻译成中文是"反应器",就是我们将事件注冊到Reactor中,当有对应的事件发生时,Reactor便会告知我们有哪些…
本篇博客依照 Java NIO Tutorial翻译,算是学习 Java NIO 的一个读书笔记.建议大家可以去阅读原文,相信你肯定会受益良多. 1. Java NIO Tutorial Java NIO,被称为新 IO(New IO),是 Java 1.4 引入的,用来替代 IO API的. Java NIO:Channels and Buffers 标准的 Java IO API ,你操作的对象是字节流(byte stream)或者字符流(character stream),而 NIO,你操…
背景知识 同步.异步.阻塞.非阻塞 首先,这几个概念非常容易搞混淆,但NIO中又有涉及,所以总结一下[1]. 同步:API调用返回时调用者就知道操作的结果如何了(实际读取/写入了多少字节). 异步:相对于同步,API调用返回时调用者不知道操作的结果,后面才会回调通知结果. 阻塞:当无数据可读,或者不能写入所有数据时,挂起当前线程等待. 非阻塞:读取时,可以读多少数据就读多少然后返回,写入时,可以写入多少数据就写入多少然后返回. 对于I/O操作,根据Oracle官网的文档,同步异步的划分标准是"调…
零.前言 这里整理摘录了我了解NIO的一些笔记. 参考资料: 1.深入浅出NIO之Channel.Buffer 2.深入浅出NIO之Selector实现原理 3.Java NIO vs. IO 一.NIO与BIO的简单对比 Java中,传统的IO,又称BIO(Blocking IO,阻塞式IO).BIO是面向流(stream)的,阻塞的. NIO(Non-Blocking IO,非阻塞式IO).NIO是面向缓存(buffer)的,非阻塞的. 1.面向流与面向缓存 BIO是面向流模式,意味着数据只…