本文目录一览:
- 1、在java中使用io,nio,aio的应用场景,有什么优劣势
- 2、JAVA NIO 和 AIO 的区别
- 3、java的aio中AsynchronousSocketChannelread第一个参数有什么用
- 4、JAVA AIO技术怎么不怎么用
- 5、为什么没有基于java aio的框架
在java中使用io,nio,aio的应用场景,有什么优劣势
nio是面向块的,先把数据搬过来,先存到缓存区里面,如果线程要用从缓存区拿。所以线程不需要时刻盯着io了,可以先做一些其他的事情,过几天再来看一下缓存。是同步非阻塞的。因此,nio里有Buffer类作为缓冲区,Channel(通道)相当于io里的steam的抽象,Selector是nio提供的管理多个Channel的工具。nio出现也是因为io渐渐成为一些程序速度的瓶颈。
JAVA NIO 和 AIO 的区别
Java NIO : 同步非阻塞,服务器实现模式为一个请求一个线程,即客户端发送的连接请求都会注册到多路复用器上,多路复用器轮询到连接有I/O请求时才启动一个线程进行处理。
Java AIO(NIO.2) : 异步非阻塞,服务器实现模式为一个有效请求一个线程,客户端的I/O请求都是由OS先完成了再通知服务器应用去启动线程进行处理,
NIO方式适用于连接数目多且连接比较短(轻操作)的架构,比如聊天服务器,并发局限于应用中,编程比较复杂,JDK1.4开始支持。
AIO方式使用于连接数目多且连接比较长(重操作)的架构,比如相册服务器,充分调用OS参与并发操作,编程比较复杂,JDK7开始支持
I/O属于底层操作,需要操作系统支持,并发也需要操作系统的支持,所以性能方面不同操作系统差异会比较明显。另外NIO的非阻塞,需要一直轮询,也是一个比较耗资源的。所以出现AIO
java的aio中AsynchronousSocketChannelread第一个参数有什么用
final ByteBuffer buffer = ByteBuffer
.allocateDirect(1024);
// transmitting data
while (asynchronousSocketChannel.read(buffer)
.get() != -1) {
buffer.flip();
}
第一个参数是字符缓冲区对象。
JAVA AIO技术怎么不怎么用
1、首先是操作系统的问题,目前Linux系统没有完全实现AIO,而windows系统虽然对于AIO支持良好,但是我们程序通常运行在Linux主机上,所以对于AIO的使用并不是很频繁。
2、其次JavaAIO在不是以IO读写为核心的并发请求中,效率上并没有比NIO出色,除非请求涉及到大量的IO操作,而我们更多的Java应用不是非常倾向IO操作。
3、最后对于网络通讯的编程,大多数的时候我们会选用现有的框架,比如Netty,而利用JavaAIO中晦涩API去实现网络通讯,对于我们大多数非网络专业的人来说,是比较困难的。
为什么没有基于java 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.