在上一篇博文中讲述了几种IO模型,现在我们开始进入Java NIO编程主题。NIO是Java 4里面提供的新的API,目的是用来解决传统IO的问题。...本文下面分别从Java NIO的几个基础概念介绍起。 ...Buffer(缓冲区),是NIO中非常重要的一个东西,在NIO中所有数据的读和写都离不开Buffer。...outputStream.getChannel(); ByteBuffer buffer = ByteBuffer.allocate(1024); String string = "java...channel.close(); outputStream.close(); } } 通过上面的程序会向工程目录下的data.txt文件写入字符串"java
NIO中,每个线程可以处理多个channel(异步)。 线程发起IO请求,立即返回;内核在做好IO操作的准备之后,通过调用注册的回调函数通知线程做IO操作,线程开始阻塞,直到操作完成 ?...2、NIO中channel肯定是非阻塞模式的,否则抛出异常。为什么呢?因为前面selector异步通知程序的时候,通道中的数据肯定是有的。 3、同步与阻塞是不同的概念,异步与非阻塞也是不同的概念。...目前Java的nio的异步看起来是阻塞的,因为阻塞在select.select()操作上了。但是其实可以通过select.wakeUp()方法,不用一直阻塞。... 版权声明:“Java后端技术”所推送文章,为本人原创、网上收集或其他作者投稿,对于网上收集部分除非确实无法确认,我们都会注明作者和来源。部分文章推送时未能与原作者取得联系。
大家好,又见面了,我是全栈君 Java NIO和流量相似,但有些差异: ·通道可读写,流仅支持单向。...读或写 ·异步通道读取 ·通道读写器,他们是和Buffer交替 道的实现 下面是Java NIO中最重要的通道的实现: ·FileChannel ·DatagramChannel ·...下一节将具体介绍Buffer:【JAVA】【NIO】4、Java NIO Buffer 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/117568.html原文链接
Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java IO API。本系列教程将有助于你学习和理解Java NIO。...下面就来详细介绍Java NIO的相关知识。 1....Java NIO 概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer...Java NIO vs IO 当学习了Java NIO和IO的API后,一个问题马上涌入脑海: 我应该何时使用IO,何时使用NIO呢?...2.1 Java NIO和IO的主要区别 下表总结了Java NIO和IO之间的主要差别,我会更详细地描述表中每部分的差异。
二.NIO原理及通信模型 Java NIO是在jdk1.4开始使用的,它既可以说成“新I/O”,也可以说成非阻塞式I/O。下面是java NIO的工作原理: 1....下面是我理解的java NIO的通信模型示意图: 三、Java NIO概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件...与这些类一起的有一些有趣的接口,但为简单起见,我尽量在概述中不提到它们。本教程其它章节与它们相关的地方我会进行解释。...java.nio.channels.Selector; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel...; import java.nio.channels.Selector; import java.nio.channels.SocketChannel; import java.util.Iterator
在Java API中提供了两套NIO,一套是针对标准输入输出NIO,另一套就是网络编程NIO。...二、NIO和IO的主要区别 下表总结了Java IO和NIO之间的主要区别: IO NIO 面向流 面向缓冲 阻塞IO 非阻塞IO 无 选择器 1、面向流与面向缓冲 Java IO和NIO...Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。...而一个NIO的实现会有所不同,下面是一个简单的例子: ByteBuffer buffer = ByteBuffer.allocate(48); int bytesRead = inChannel.read...Java NIO: 单线程管理多个连接 如果你有少量的连接使用非常高的带宽,一次发送大量的数据,也许典型的IO服务器实现可能非常契合。下图说明了一个典型的IO服务器设计: ?
NIO阻塞式 3. Selector(选择器) 3.1. SelectionKey 3.2. NIO非阻塞式 4....DatagramChannel:UDP 获取通道 本地IO,提供了getChannel()方法获取通道 FileInputStream FileOutputStram RandomAccessFile 在JDK1.7中的NIO...,针对各个通道提供了静态方法open() 在JDK1.7中的NIO的Files工具类的newByteChannel() 实例 利用通道实现文件的复制(非直接缓冲区) /** * 使用getChannel...写入数据的通道 //聚集写入,将数据从各个缓冲区中写入到通道中 outChannel.write(dst); inchannel.close(); outChannel.close(); } NIO...阻塞式 阻塞或者不阻塞是针对SocketChannel,ServerSocketChannel NIO中的套接字可以轻松在阻塞和非阻塞之间切换,这里我们使用NIO实现阻塞式的TCP数据传输 /**
了解java的NIO,需要先了解同步异步以及阻塞非阻塞的概念,同步/异步,阻塞/非阻塞 NIO就是采用的同步非阻塞这种组合方式。或简单一点,采用的是IO复用的策略,可以使用一个线程管理多个IO连接。...Java中的NIO 原理接说到这里,下面看一下jdk中NIO的实现和用法。jdk中的NIO的实现,主要几个部分是Channel(通道),Buffer(缓冲区),Selector(选择器)。...在调用Selector的open方时,就已经根据操作系统、内核版本决定了采用哪种IO复用策略,简单看一下sun.nio.ch.DefaultSelectorProvider#create里Selector...参考文章: Java NIO系列教程 Java NIO:NIO概述 Java IO & NIO & NIO2 Java 网络 IO 模型 Java NIO系列教程(六) 多路复用器Selector Java...网络IO编程总结(BIO、NIO、AIO均含完整实例代码) Java NIO 反应堆模式简单模型 Java NIO(7): Epoll版的Selector Linux IO模式及 select、poll
下面使用NIO编写了一个简单的聊天程序,服务端将客户端发来的消息广播给所有客户端。...import java.nio.ByteBuffer; import java.nio.channels.SelectionKey; import java.nio.channels.Selector;...import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.nio.charset.Charset...; import java.nio.ByteBuffer; import java.nio.channels.SelectionKey; import java.nio.channels.Selector...; import java.nio.channels.SocketChannel; import java.time.LocalDateTime; import java.util.Iterator;
二.NIO原理及通信模型 Java NIO是在jdk1.4开始使用的,它既可以说成“新I/O”,也可以说成非阻塞式I/O。下面是java NIO的工作原理: 1....下面是我理解的java NIO的通信模型示意图: image.png 三、Java NIO 概述 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然...与这些类一起的有一些有趣的接口,但为简单起见,我尽量在概述中不提到它们。本教程其它章节与它们相关的地方我会进行解释。...;import java.nio.ByteBuffer;import java.nio.channels.SelectionKey;import java.nio.channels.Selector;import...java.nio.channels.ServerSocketChannel;import java.nio.channels.SocketChannel;import java.util.Iterator
java标准IO回顾 Java 标准 IO 类库是 io 面向对象的一种抽象。基于本地方法的底层实现,我们无须关注底层实现。...java NIO简介 Java NIO(New IO Non Blocking IO)是从Java1.4版本开始引入的一个新的IO API,可以替代标准的Java IO API。...看到NIO这么多的优点,是不是有点小激动。继续看一下他们的区别。 Java NIO与IO的主要区别 下表总结了Java NIO和IO之间的主要差别,我会更详细地描述表中每部分的差异。...Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。...通道与缓冲区 Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)。 Buffer:表示打开到IO设备(例如:文件、套接字)的连接。 是一块连续的内存块。
Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Selector...下面是JAVA NIO中的一些主要Channel的实现: FileChannel DatagramChannel SocketChannel ServerSocketChannel 正如你所看到的,这些通道涵盖了...与这些类一起的有一些有趣的接口,但为简单起见,我尽量在概述中不提到它们。本教程其它章节与它们相关的地方我会进行解释。...以下是Java NIO里关键的Buffer实现: ByteBuffer CharBuffer DoubleBuffer FloatBuffer IntBuffer LongBuffer ShortBuffer...Java NIO 还有个 Mappedyteuffer,用于表示内存映射文件, 我也不打算在概述中说明。 Selector Selector允许单线程处理多个 Channel。
Java Path接口是Java NIO2一部分,是对Java6 和Java7的更新。...Java的Path接口在Java7中被添加到Java NIO中,位于java.nio.file包中,全路径名为是java.nio.file.Path。...java.nio.file.Path实例和环境变量中的Path没有任何关系。 很多地方java.nio.file.Path接口和java.io.File类是类似的,但是有一些不同。...创建一个Path实例 为了使用Java.nio.file.Path实例,需要创建Path实例。...下面是一个Java Paths.get()的例子: import java.nio.file.Path; import java.nio.file.Paths; public class PathExample
本篇文章,我们来说说 Selector 的应用,如标题所示,这里我基于 Java NIO 实现了一个简单的 HTTP 服务器。在接下来的章节中,我会详细讲解 HTTP 服务器实现的过程。...实现 本节所介绍的 HTTP 服务器是一个很简单的实现,仅支持 HTTP 协议极少的特性。包括识别文件后缀,并返回相应的 Content-Type。...2.1 处理请求 处理请求的逻辑比较简单,主要的工作是解析消息头。...处理请求的逻辑很简单,不多说了。 2.2 响应请求 看完处理请求的逻辑,接下来再来看看响应请求的逻辑。...这个是我写 NIO 系列文章的一个感触。 好了,本文到这里结束。谢谢阅读!
当学习了Java NIO和IO的API后,一个问题马上涌入脑海: 我应该何时使用IO,何时使用NIO呢?...在本文中,我会尽量清晰地解析Java NIO和IO的差异、它们的使用场景,以及它们如何影响您的代码设计。...Java NIO和IO的主要区别 下表总结了Java NIO和IO之间的主要差别,我会更详细地描述表中每部分的差异。...Java NIO的非阻塞模式,使一个线程从某通道发送请求读取数据,但是它仅能得到目前可用的数据,如果目前没有数据可用时,就什么都不会获取。...(Java IO: 从一个阻塞的流中读数据) 而一个NIO的实现会有所不同,下面是一个简单的例子: 1 ByteBuffer buffer = ByteBuffer.allocate(48); 2
多数通道都是链接到开发的文件描述符的。Channel类提供维持平台独立性的抽象过程。
NIO(Non-blocking I/O,在Java领域,也称为New I/O),是一种同步非阻塞的I/O模型,也是I/O多路复用的基础,已经被越来越多地应用到大型应用服务器,成为解决高并发与大量连接...NIO与IO的主要区别 IO是面向流的,NIO是面向缓冲区的。Java IO面向流意味着每次只能从流中读取一个或多个字节,直到读取完所有字节,它们没有被缓存在任何地方。此外,它不能前后移动流中的数据。...NIO NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式。 ...Java NIO引入了选择器的概念,选择器用于监听多个通道的事件(比如:连接打开,数据到达)。因此,单个的线程可以监听多个数据通道。 缓冲区(Buffer): 为什么说NIO是基于缓冲区的IO方式呢?...相关链接:美团技术团队-java NIO浅析
所以,jdk 1.4 发布了 NIO 包,NIO 的文件读写设计颠覆了传统 IO 的设计,采用『通道』+『缓存区』使得新式的 IO 操作直接面向缓存区,并且是非阻塞的,对于效率的提升真不是一点两点,我们一起来看看...通道 Channel 我们说过,NIO 的核心就是通道和缓存区,所以它们的工作模式是这样的: ?...这是一块物理内存,专门用于 JVM 和 IO 设备打交道,Java 底层使用 C 语言的 API 调用操作系统与 IO 设备进行交互。...第三第四部分比较简单,这里不再赘述了。...选择器 Selector Selector 是 Java NIO 的一个组件,它用于监听多个 Channel 的各种状态,用于管理多个 Channel。
Java NIO简介 Java NIO(New IO)是从Java 1.4版本开始引入的 一个新的IO API,可以替代标准的Java IO API。...Java NIO和 IO的主要区别 传统IO-面向流 NIO-面向通道 后面两条区别技术针对网络通信来说的,后面再涉及。...通道和缓冲区 Java NIO系统的核心在于:通道(Channel)和缓冲区 (Buffer)。通道表示打开到 IO 设备(例如:文件、 套接字)的连接。...简而言之,Channel 负责传输, Buffer 负责存储 缓冲区 案例代码: /* * 一、缓冲区(Buffer):在 Java NIO 中负责数据的存取。缓冲区就是数组。...在Java NIO 中负责缓冲区中的数据传输。 Channel 本身不能存数据,因此需要配合缓冲区进行传输。
NIO 概念 我们传统上处理socket IO时, 需要给每一个连接创建一个线程, 当并发的连接数量非常大的时候, 线程所占用的栈内存和CPU线程切换的开销将非常大....如果使用NIO, 那么不需要为每一个连接创建一个单独的线程, 可以用一个含有有限数量线程的线程池, 甚至是一个线程来为任意数量的连接提供服务....实例 import java.io.IOException; import java.io.OutputStream; import java.net.InetSocketAddress; import...java.net.ServerSocket; import java.net.Socket; import java.nio.ByteBuffer; import java.nio.channels.SelectionKey...; import java.nio.channels.Selector; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel
领取专属 10元无门槛券
手把手带您无忧上云