随笔 @Java领域中相关通信点(二)

夜光序言:

如果可以,请做一个任性的人,因为总有一天,你会遇到那个可以包容你所有坏脾气的人

 

正文:

6 AIO  编程


Asynchronous IO: 异步非阻塞的编程方式与 NIO 不同,当进行读写操作时,只须直接调用 API 的 read 或 write 方法即可。

 

这两种方法均为异步的,对于读操作而言,当有流可读取时,操作系统会将可读的流传入 read 方法的缓冲区,并通知应用程序;对于写操作而言,当操作系统将 write 方法传递的流写入完毕时,操作系统主动通知应用程序。

 

即可以理解为,read/write 方法都是异步的,完成后会主动调用回调函数。

 

在 JDK1.7 中,这部分内容被称作 NIO.2,主要在 java.nio.channels 包下增加了下面四个异步通道:


AsynchronousSocketChannel
AsynchronousServerSocketChannel
AsynchronousFileChannel
AsynchronousDatagramChannel


异步非阻塞,服务器实现模式为一个有效请求一个线程,客户端的 I/O 请求都是由 OS先完成了再通知服务器应用去启动线程进行处理。


AIO 方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用 OS 参与并发操作,编程比较复杂,JDK7 开始支持。

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值