从socket中读取数据时使用超时

王朝other·作者佚名  2008-05-31
宽屏版  字体: |||超大  

Java 1.4在Java API加入了非阻塞I/O(non-blocking I/O),不过Java 1.3和更早的版本都不支持这样的特性。然而,你可以用java.net.Socket类的超时属性来获得一些类似于非阻塞I/O的功能。

要使用超时属性,首先你要创建一个socket,然后设置你期望的超时时间。setSoTimeout方法有一个参数,这个int型参数指定了socket在抛出一个违例前要等待的超时时间,单位是毫秒,像下面的例子:

Socket s = new Socket(server, port);

System.out.println(s.getSoTimeout());

s.setSoTimeout(5000);

InputStream in = s.getInputStream();

现在我们尝试从这个socket中读数据。假如超过了指定的时间还读不到任何数据,程序将抛出一个java.io.InterruptedIOException。你可以捕捉这一违例并决定是否尝试进行另一次读取操作:

try {

while ( (bytesRead = in.read(buffer)) != -1 ) {

// do something with the data

System.out.println

(new String(buffer, 0, bytesRead));

}

}

catch (InterruptedIOException e) {

System.err.print("timeout on read");

// 决定是否继续读取

}

在早于1.4的Java版本中,当从socket中读取数据时,你的程序不得不阻塞起来,但并不意味着你的程序这时什么也不能做。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有