java nio模型_技术分享:JAVA NIO模型

原标题:技术分享:JAVA NIO模型

最近一直在问到Java NIO 与操作系统IO之间的关系。事实上,JAVA NIO的网络模型依赖了操作系统的NIO模型。JAVA的NIO底层的依赖实现就是操作系统的NIO模型。从DefaultSelectorProvider的源码就可以看出来:

在Windows下:

/**

* Creates this platform's default SelectorProvider

*/

public class DefaultSelectorProvider {

/**

* Prevent instantiation.

*/

private DefaultSelectorProvider() { }

/**

* Returns the default SelectorProvider.

*/

public static SelectorProvider create() {

return new sun.nio.ch.WindowsSelectorProvider();

}

}复制代码

可见是Windows的SelectorProvider。在Linux下:

public class DefaultSelectorProvider {

/**

* Prevent instantiation.

*/

private DefaultSelectorProvider() { }

/**

* Returns the default SelectorProvider.

*/

public static SelectorProvider create() {

String osname = AccessController.doPrivileged(

new GetPropertyAction(os.name));

if (SunOS.equals(osname)) {

return new sun.nio.ch.DevPollSelectorProvider();

}

// use EPollSelectorProvider for Linux kernels = 2.6

if (Linux.equals(osname)) {

String osversion = AccessController.doPrivileged(

new GetPropertyAction(os.version));

String[] vers = osversion.split(\\., 0);

if (vers.length = 2) {

try {

int major = Integer.parseInt(vers[0]);

int minor = Integer.parseInt(vers[1]);

if (major 2 || (major == 2 minor = 6)) {

return new sun.nio.ch.EPollSelectorProvider();

}

} catch (NumberFormatException x) {

// format not recognized

}

}

}

return new sun.nio.ch.PollSelectorProvider();

}

}

可以如果linux版本大于2.6的话用的是EPoll,小于2.6用的Poll。 Epoll是Linux下多路复用IO接口select/poll的增强版本,它能显著提高程序在大量并发连接中只有少量活跃的情况下的系统CPU利用率,因为它会复用文件描述符集合来传递结果而不用迫使开发者每次等待事件之前都必须重新准备要被侦听的文件描述符集合,另一点原因就是获取事件的时候,它无须遍历整个被侦听的描述符集,只要遍历那些被内核IO事件异步唤醒而加入Ready队列的描述符集合就行了。epoll除了提供select/poll那种IO事件的电平触发(Level Triggered)外,还提供了边沿触发(Edge Triggered),这就使得用户空间程序有可能缓存IO状态,减少epoll_wait/epoll_pwait的调用,提高应用程序效率。 另外,Java NIO在java自身的语言层面上,使用了缓存和内存映射来提高IO的读写效率。返回搜狐,查看更多

责任编辑:

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值