JDK1.4新I/O带来了非阻塞 I/O,并采用内存映射文件的方式来处理I/O,这样提高了java的输入输出速度。我们知道,系统运行的性能瓶颈通常在I/O读写,包括对端口和文件的操作上,过去,在打开一个I/O通道后,read()将一直等待在端口一边读取字节内容,如果没有内容进来,read()也是傻傻的等,这会影响我们程序继续做其他事情,那么改进做法就是开设线程,让线程去等待,但是这样做也是相当耗费资源的。
Java NIO非堵塞技术实际是采取Reactor模式,或者说是Observer模式为我们监察I/O端口,如果有内容进来,会自动通知我们,这样,我们就不必开启多个线程死等,从外界看,实现了流畅的I/O读写,不堵塞了。
废话少说,会用才是关键,具体如何实现我也没研究过,如有兴趣的可以研究下告诉大家,我就讲如何用的例子,eg
习惯了旧I/O会有疑问:怎么一下就把整个文件全部取出来了啊,内存映射会不会有问题?
其实太大的话也是有问题的,以下有个折中的方法,eg
最后讲下 JDK1.4还给我们提供了文件锁的功能,可以避免2个线程修改同一个文件的情况,eg
本文介绍Java NIO中文件操作的基本用法,通过示例展示了如何利用FileChannel进行文件复制,并使用内存映射文件提高I/O效率,同时介绍了文件锁的使用以确保线程安全。
576

被折叠的 条评论
为什么被折叠?



