首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2SE开发 >

4:能够在规定的时间内抛出异常[java.net.SocketTimeoutException:

2011-11-26 
关于Socket设置连接超时程序代码:SocketsocketnewSocket()SocketAddressendpointnewInetSocketAddress(

关于Socket设置连接超时
程序代码:
Socket   socket   =   new   Socket();
                SocketAddress   endpoint   =   new   InetSocketAddress( "192.168.30.23 ",   11);
                long   time   =   System.currentTimeMillis();
                try   {
                        socket.connect(endpoint,   2000);
                }   catch   (Exception   e)   {
                }

                time   =   System.currentTimeMillis()   -   time;
                System.out.println(time);
                socket.close();
当要连接的计算机[192.168.30.23]在网路上不存在的时候:
JDK1.4:能够在规定的时间内抛出异常[java.net.SocketTimeoutException:   connect   timed   out],结束阻塞。
JDK1.5:没有在规定时间内抛出异常,结束阻塞。
JDK1.6:能够在规定的时间内抛出异常[java.net.SocketTimeoutException:   connect   timed   out],结束阻塞。

结论:我猜测会不会是JDK1.5的连接超时需要特殊的设置,或者是JDK1.5的实现有问题。

我的JDK1.5的版本如下:
java   version   "1.5.0-rc "
Java(TM)   2   Runtime   Environment,   Standard   Edition   (build   1.5.0-rc-b63)
Java   HotSpot(TM)   Client   VM   (build   1.5.0-rc-b63,   mixed   mode,   sharing)

求助:
不知道大家是否也遇到过类似的问题,或者看到过相关的文献对此种情况有说明。



[解决办法]
一直在学Socket

帮顶
学习
[解决办法]
try {
socket.connect(endpoint, 2000);
} catch (Exception e) {
}
=========================
你测试的代码就是这样?能打印出异常?
[解决办法]
楼主简化了程序吧?
[解决办法]
学习

[解决办法]
我就用的是1.5的也出现了和楼主的情况相同。
JDK1.5:没有在规定时间内抛出异常,结束阻塞。
用不同IP抛出的异常的时间也是不同的。这又是什么原因呢?

热点排行
Bad Request.