JAVA AIO技术怎么不怎么用

Python016

JAVA AIO技术怎么不怎么用,第1张

1、首先是操作系统的问题,目前Linux系统没有完全实现AIO,而windows系统虽然对于AIO支持良好,但是我们程序通常运行在Linux主机上,所以对于AIO的使用并不是很频繁。

2、其次JavaAIO在不是以IO读写为核心的并发请求中,效率上并没有比NIO出色,除非请求涉及到大量的IO操作,而我们更多的Java应用不是非常倾向IO操作。

3、最后对于网络通讯的编程,大多数的时候我们会选用现有的框架,比如Netty,而利用JavaAIO中晦涩API去实现网络通讯,对于我们大多数非网络专业的人来说,是比较困难的。

Java NIO : 同步非阻塞,服务器实现模式为一个请求一个线程,即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有I/O请求时才启动一个线程进行处理。

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

NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持。

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

I/O属于底层操作,需要操作系统支持,并发也需要操作系统的支持,所以性能方面不同操作系统差异会比较明显。另外NIO的非阻塞,需要一直轮询,也是一个比较耗资源的。所以出现AIO

如果是指基于jdk7的aio,确实没有,但是如果说是异步事件驱动,netty就算是的。

jre1.7后才只支持aio,但是实际上netty框架就是支持异步IO的了。

Netty:

Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers &clients.