{
try
{
client.close();
}catch(IOException e1){}
}
}
/**
* 进行向客户端写数据操作
* @param key 客户端选择键对象
*/
private void doClinetWriteEvent(SelectionKey key)
{
代码实现略;
}
/**
* 进行读取客户短数据操作
* @param key 客户端选择键对象
*/
private void doClientReadEvent(SelectionKey key)
{
代码实现略;
}
}
从上面对代码可以看出,使用非阻塞性I/O进行并发型服务器程序设计分三个部分:1.向Selector对象注册感兴趣的事件;2.从Selector中获取所感兴趣的事件;3.根据不同的事件进行相应的处理。
结语
通过使用NIO 工具包进行并发型服务器程序设计,一个或者很少几个Socket 线程就可以处理成千上万个活动的Socket 连接,大大降低了服务器端程序的开销;同时网络I/O 采取非阻塞模式,线程不再在读或写时阻塞,操作系统可以更流畅的读写数据并可以更有效地向CPU 传递数据进行处理,以便更有效地提高系统的性能。
看到这里相信你看了不止30分钟了吧, 我说30分钟其实就是想让大家能够轻松的读下去(鸡蛋。。。)
好了,到这里大家应该对java nio有个初步的了解了吧~~~
下次给大家带来一个java nio开发的实例吧~~
责任编辑:小草