运用异步输入输出流编写Socket进程通信 - 编程入门网
运用异步输入输出流编写Socket进程通信时间:2010-12-14 杨健同步?异步输入输出机制的引入 在Merlin之前,编写Socket程序是比 较繁琐的工作.因为输入输出都必须同步.这样,对于多客户端客户/服务器模式, 不得不使用多线程.即为每个连接的客户都分配一个线程来处理输入输出.由此而 带来的问题是可想而知的.程序员不得不为了避免死锁,线程安全等问题,进行大 量的编码和测试.很多人都在抱怨为什么不在Java中引入异步输入输出机制.比较 官方的解释是,任何一种应用程序接口的引入,都必须兼容任何操作平台.因为 Java是跨平台的.而当时支持异步输入输出机制的操作平台显然不可能是全部.自 Java 2 Platform以后,分离出J2SE,J2ME,J2EE三种不同类型的应用程序接口,以 适应不同的应用开发.Java标准的制订者们意识到了这个问题,并且支持异步输入 输出机制的操作平台在当今操作平台中处于主流地位.于是,Jdk(J2SE) 的第五次 发布中引入了异步输入输出机制. 以前的Socket进程通信程序设计中,一 般客户端和服务器端程序设计如下: 服务器端:
客户端:
以上代码段只是用同步机制编写 Socket进程通信的一个框架,实际上要考虑的问题要复杂的多(有兴趣的读者可 以参考我的一篇文章《Internet 实时通信系统设计与实现》)。将这样一个框 架列出来,只是为了与用异步机制实现的Socket进程通信进行比较。下面将介绍 使用异步机制的程序设计。 用异步输入输出流编写Socket进程通信程序 在Merlin中加入了用于实现异步输入输出机制的应用程序接口包: java.nio(新的输入输出包,定义了很多基本类型缓冲(Buffer)), java.nio.channels(通道及选择器等,用于异步输入输出),java.nio.charset (字符的编码解码)。通道(Channel)首先在选择器(Selector)中注册自己感兴 趣的事件,当相应的事件发生时,选择器便通过选择键(SelectionKey)通知已注 册的通道。然后通道将需要处理的信息,通过缓冲(Buffer)打包,编码/解码, 完成输入输出控制。 通道介绍: 这里主要介绍 ServerSocketChannel和 SocketChannel.它们都是可选择的(selectable)通道, 分别可以工作在同步和异步两种方式下(注意,这里的可选择不是指可以选择两 种工作方式,而是指可以有选择的注册自己感兴趣的事件)。可以用 channel.configureBlocking(Boolean )来设置其 |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |