
NIO
wallxu
这个作者很懒,什么都没留下…
展开
-
Java-NIO(四):通道(Channel)的原理与获取
通道(Channel): 由java.nio.channels包定义的,Channel表示IO源与目标打开的连接,Channel类似于传统的“流”,只不过Channel本身不能直接访问数据,Channel只能与Buffer进行交互。通道主要用于传输数据,从缓冲区的一侧传到另一侧的实体(如文件、套接字...),反之亦然;通道是访问IO服务的导管,通过通道,我们可以以最小的开销来访问操作系统转载 2017-12-19 14:03:44 · 360 阅读 · 0 评论 -
Java-NIO(一):简介
Java NIO简介:Java New IO Non Blocking IO,从java1.4版本就开始引入了新的IO API,可以替代标准的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同,NIO支持面向缓冲区的、基于通道的IO操作。NIO将更加高效的方式进行文件的读写操作。Java NIO与IO的区别:IONIO转载 2017-12-18 16:42:53 · 238 阅读 · 0 评论 -
Java-NIO(二):缓冲区(Buffer)的数据存取
缓冲区(Buffer): 一个用于特定基本数据类行的容器。有java.nio包定义的,所有缓冲区都是抽象类Buffer的子类。 Java NIO中的Buffer主要用于与NIO通道进行交互,数据是从通道读入到缓冲区,从缓冲区写入通道中的。 Buffer就像一个数组,可以保存多个相同类型的数据。根据类型不同(boolean除外),有以下Buffer常用子类:By转载 2017-12-18 16:55:47 · 371 阅读 · 0 评论 -
Java-NIO(三):直接缓冲区与非直接缓冲区
直接缓冲区与非直接缓冲区的概念:1)非直接缓冲区:通过static ByteBuffer allocate(int capacity)创建的缓冲区,在JVM中内存中创建,在每次调用基础操作系统的一个本机IO之前或者之后,虚拟机都会将缓冲区的内容复制到中间缓冲区(或者从中间缓冲区复制内容),缓冲区的内容驻留在JVM内,因此销毁容易,但是占用JVM内存开销,处理过程中有复制操作。转载 2017-12-19 13:43:15 · 908 阅读 · 0 评论 -
Java-NIO(九):管道 (Pipe)
Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。代码使用示例: 1 @Test 2 public void testPipe() throws IOException { 3 // 1、获取通道 4 Pipe pi转载 2017-12-20 15:32:32 · 468 阅读 · 0 评论 -
Java-NIO(八):DatagramChannel
Java NIO中的DatagramChannel是一个能收发UDP包的通道。操作步骤: 1)打开 DatagramChannel 2)接收/发送数据同样它也支持NIO的非阻塞模式操作,例如:1@Test 2 public void send() throws IOException { 3 DatagramChannel chan转载 2017-12-20 15:32:03 · 251 阅读 · 0 评论 -
Java-NIO(七):阻塞IO与非阻塞IO
阻塞IO 传统的 IO 流都是阻塞式的。 也就是说,当一个线程调用 read() 或 write()时,该线程被阻塞,直到有一些数据被读取或写入,该线程在此期间不能执行其他任务。 因此,在完成网络通信进行 IO 操作时,由于线程会阻塞,所以服务器端必须为每个客户端都提供一个独立的线程进行处理,当服务器端需要处理大量客户端时,性能急剧下降。 注意:在阻塞IO操转载 2017-12-20 15:31:30 · 953 阅读 · 0 评论 -
Java-NIO(六):Channel聚集(gather)写入与分散(scatter)读取
Channel聚集(gather)写入:聚集写入( Gathering Writes)是指将多个 Buffer 中的数据“聚集”到 Channel。 特别注意:按照缓冲区的顺序,写入 position 和 limit 之间的数据到 Channel 。 Channel分散(scatter)读取:分散读取( Scattering Reads)是指从 Channe转载 2017-12-20 15:30:34 · 279 阅读 · 0 评论 -
Java-NIO(五):通道(Channel)的数据传输与内存映射文件
通道(Channel)的数据传输(采用非直接缓冲区)1@Test 2 public void testChannel() throws IOException { 3 FileInputStream fileInputStream = new FileInputStream("Java NIO.pdf"); 4 FileOutputStr转载 2017-12-20 15:29:46 · 382 阅读 · 0 评论