Java提供哪些IO方式?Nio如何实现多路复用?
传统的Java.io包中,它基于流模型实现,提供了我们熟知的IO功能
交互方式是同步、阻塞的方式,在读取输入流或者写入输出流时,在读写动作完成之前,线程会一直阻塞在那里,他们之间的调用是可靠的线程顺序
不过Java.io包下的好处是代码简单易懂、直观,缺点是Io效率和扩展性存在局限,容易成为应用性能的瓶颈。
有时候,人们也会把Java.net下面提供的部分网络API,比如Socket、ServerSocket、HttpURLConnection也归类为同步阻塞IO类库,因为网络通信也是IO行为
第二,在Java1.4中引入了NIO框架(java.nio),提供了Channel、Selector、Buffer等新抽象,可以构建多路复用的、同步非阻塞的io程序,同时提供了跟接近操作系统底层的高性能数据操作方式。
第三,在Java7中,NIO有了进一步的改进,也就是NIO2,引入了异步非阻塞的io方式,也有人叫它AIO(asynchronous IO)。异步IO操作基于事件和回调机制,可以简单理解为,应用操作直接返回,而不会阻塞在那里,当后台完成后,操作系统会通知相应线程进行后续工作。