程序代码:
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抛出的异常的时间也是不同的。这又是什么原因呢?