2.Java NIO 简介

Java NIO详解
本文介绍了Java NIO(New IO)的基本概念及其与传统Java IO的主要区别。NIO通过面向缓冲区、基于通道的IO操作提高了文件读写效率,并详细解释了NIO如何减少数据拷贝次数来提升性能。

概述

  Java NIO 是 JDK 1.4 发布的一套全新的IO API(New IO 简称 NIO),由于 JDK 1.7 对 NIO 的更新,目前 NIO 被广泛应用,以至于

将 JDK 1.7 的改动称为 NIO.2,NIO 可以替代传统的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用方式及原理有很大

不同。NIO支持面向缓冲区的、基于通道的IO操作。并且,NIO将以更加高效的方式进行文件的读写操作

1.Java NIO与IO的主要区别

  

1.1.传统的I/O(数据传输:文件、网络)

  使用传统的I/O程序读取文件内容, 并写入到另一个文件(或Socket),会有较大的性能开销

  

  1) 先将文件内容从磁盘中拷贝到操作系统buffer

  2) 再从操作系统buffer拷贝到程序应用buffer

  3) 从程序buffer拷贝到socket buffer

  4) 从socket buffer拷贝到协议引擎.

1.2.NIO

  NIO技术省去了将操作系统的read buffer拷贝到程序的buffer, 以及从程序buffer拷贝到socket buffer的步骤, 直接将 read buffer

拷贝到 socket buffer,java 的 FileChannel.transferTo() 方法就是这样的实现, 这个实现是依赖于操作系统底层的sendFile()实现的.

  

NIO 即 non-blocking IO,是一种非阻塞式的 IO,NIO 三大核心部分:Channel(通道),Buffer(缓冲区), Selector(选择器)

1.通道和缓冲区:Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)

  通道表示打开到 IO 设备(例如:文件、套接字)的连接。若需要使用 NIO 系统,需要获取用于连接 IO 设备的通道以及用于

容纳数据的缓冲区。然后操作缓冲区,对数据进行处理(通道只是用于获取连接,数据由Buffer传输

  简而言之,Channel 负责传输(铁路), Buffer 负责存储(火车)

 

  

 

  

  

  

 

 

 

 

  

 

  

  

  

  

转载于:https://www.cnblogs.com/yaboya/p/9171337.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值