JAVA NIO 简介_亮仔_新浪博客

本文深入探讨了Java NIO的原理和应用,包括Channel、Buffer等核心概念,以及其提供的新API特性如缓存支持、多路非阻塞式高伸缩性网络I/O等。通过实例学习如何高效进行数据读写。

1.   基本 概念

IO 是主存和外部设备 ( 硬盘、终端和网络等 ) 拷贝数据的过程。 IO 是操作系统的底层功能实现,底层通过 I/O 指令进行完成。

所有语言运行时系统提供执行 I/O 较高级别的工具。 (c 的 printf scanf,java 的面向对象封装 )

2.    Java 标准 io 回顾

Java 标准 IO 类库是 io 面向对象的一种抽象。基于本地方法的底层实现,我们无须关注底层实现。 InputStream\OutputStream( 字节流 ) :一次传送一个字节。 Reader\Writer( 字符流 ) :一次一个字符。

3.    nio 简介

nio 是 java New IO 的简称,在 jdk1.4 里提供的新 api 。 Sun 官方标榜的特性如下:

     为所有的原始类型提供 (Buffer) 缓存支持。

     字符集编码解码解决方案。

     Channel :一个新的原始 I/O 抽象。

     支持锁和内存映射文件的文件访问接口。

     提供多路 (non-bloking) 非阻塞式的高伸缩性网络 I/O 。

本文将围绕这几个特性进行学习和介绍。

4.   Buffer&Chanel

Channel 和 buffer 是 NIO 是两个最基本的数据类型抽象。

Buffer:

        是一块连续的内存块。

        是 NIO 数据读或写的中转地。

Channel:

        数据的源头或者数据的目的地

        用于向 buffer 提供数据或者读取 buffer 数据 ,buffer 对象的唯一接口。

         异步 I/O 支持

JAVA <wbr>NIO <wbr>简介


图1:channel和buffer关系
 

 

例子 1:CopyFile.java:

 

Java代码  

0

阅读 评论 收藏 转载 喜欢 打印 举报/Report
加载中,请稍候......
  • 评论加载中,请稍候...
发评论

登录名:密码:找回密码 注册 记住登录状态

昵   称:

评论并转载此博文6d4327fd1c1b0c64cf2a3973779c0eb4.gif

发评论

以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值