📄 java中的异步网络编程.htm
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0057)http://eps.www85.cn4e.com/java/article/devshow.asp?id=155 -->
<HTML><HEAD><title>csdn_Java中的异步网络编程</TITLE>
<META content="text/html; charset=gb2312" http-equiv=Content-Type>
<STYLE type=text/css>TD {
FONT-FAMILY: "Verdana", "Arial", "宋体"; FONT-SIZE: 9pt
}
A {
COLOR: #660000; TEXT-DECORATION: underline
}
A:hover {
COLOR: #660000; TEXT-DECORATION: none
}
.line {
LINE-HEIGHT: 14pt
}
</STYLE>
<META content="MSHTML 5.00.2920.0" name=GENERATOR></HEAD>
<BODY bgColor=#ffffff text=#000000>
<table>
<TBODY>
<TR>
<TD height=21>
<DIV align=center><B><FONT size=3>Java中的异步网络编程 <BR><FONT
size=2>
</FONT></FONT></FONT>
<HR align=center color=#cccccc noShade SIZE=1>
</DIV></TD></TR>
<TR>
<TD class=line><FONT
color=#333300>Java中的异步网络编程 <BR><BR>[ 作者: 郭洪锋 添加时间: 2001-9-10 20:53:32 ]<BR><BR> <BR><BR>对程序员有所帮助 <BR>郭洪锋 (ghf_emai@china.com)<BR><BR>该文章对编写客户服务器应用的java程序员有所帮助,可以解决程序在对方出现故障的时候继续稳定运行.<BR>目前java平台已经广泛应用于各类客户/服务器系统中,在实际编程中,往往需要网络的异步处理。比如客户程序,如果客户程序运行先于服务程序,则客户程序则需要在服务程序启动后再自动连接服务程序;在客户程序运行中如果服务程序中途停止,则也需要在不停止的条件下,等待服务程序运行并重新连接。下面提供了一类异步编程的方法。<BR><BR>网络异步应用涉及到如下几个关键点: <BR><BR>客户应用启动后,检测服务应用是否存在。如果不存在,则等待服务应用启动,同时不堵塞客户应用其他任务的执行。一旦服务应用启动,客户应用应该及时的与其建立连接。 <BR>客户应用和服务应用在数据通信中,服务应用异常退出后,客户应用应可以检测到服务应用的退出。同时客户应用自动清除该通信链路,回到初始状态,等待服务应用重新启动。<BR><BR>该网络异步编程首先涉及到一个定时器和定时器事件。该定时器用于不断的检测网络中客户应用和服务应用是否连通,同时在服务应用出现异常时中止数据通信,返回到初始状态。网络的故障可以通过网络方法的异常处理获知。<BR><BR>定时器包含在网络通信类中,使得使用该类的应用感知不到定时器的存在,而方便的处理网络信息。<BR><BR>该客户程序类如下结构: <BR>public class NetComm <BR> implements ActionListener<BR>{<BR> <BR>javax.swing.Timer timer = new javax.swing.Timer(3000,this);<BR> <BR>Socket sock;<BR>private EventNotifier en;<BR>public static int net_state = 0;<BR>InetAddress ServerAddr;<BR>int ServerPort;<BR> <BR>public NetComm(InetAddress addr, int port){<BR> ServerAddr = addr;<BR> ServerPort = port;<BR>}<BR><BR>public void NetComm_Init() {<BR> <BR> net_state = 1;<BR> try {<BR> sock = new Socket(ServerAddr, ServerPort);<BR> } catch (IOException e) {<BR> net_state = 0;<BR> }<BR> timer.start();<BR>}<BR> <BR>public void NetComm_Data()<BR>{<BR> try {<BR> OutputStream outputstream = sock.getOutputStream();<BR> <BR> BufferedWriter out = new BufferedWriter<BR> (new OutputStreamWriter(outputstream));<BR> <BR> out.write("java by ghf@china.com");<BR> out.flush();<BR><BR> BufferedReader in = new BufferedReader<BR> (new InputStreamReader(sock.getInputStream()));<BR> <BR> boolean more = true;<BR> while(more) {<BR> String str = in.readLine(); <BR> if(str == null) more = false;<BR> else<BR> // 处理数据 <BR> System.out.println(str);<BR> }<BR> <BR> in.close();<BR><BR> } catch (IOException e) {<BR> NetComm_Close();<BR> net_state = 0;<BR> }<BR> timer.start();<BR> }<BR> <BR> public void NetComm_Close()<BR> {<BR> if(sock != null)<BR> try{<BR> sock.close();<BR> } catch ( IOException e) {<BR> }<BR> }<BR> <BR> public void actionPerformed(ActionEvent e)<BR> {<BR> if(net_state == 0)<BR> NetComm_Init();<BR> else<BR> NetComm_Data();<BR> }<BR>}<BR><BR><BR><BR><BR>在以上程序中,也可以为外部应用提供一个回调函数,以便在网络异常或恢复正常时通知应用。服务应用的网络通信类类似,可以放在同一类中。<BR><BR>关于作者 <BR>郭洪锋,从事UNIX系统上的分布式应用系统开发,已有四年分布式应用系统开发经验。E-mail:ghf_email@china.com。 <BR></FONT></TD></TR>
<TR>
<TD height=5>
<HR align=center color=#cccccc noShade SIZE=1>
</TD></TR></TBODY></BODY></HTML>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -