我正在尝试对 SOCKS 代理列表进行排序,并找出哪些连接和读取时间小于 1000 毫秒,这是我的代码
for(Proxy p : proxies) {
try {
URLConnection testConnection = testUrl.openConnection(p);
testConnection.setConnectTimeout(TIMEOUT_VALUE);
testConnection.setReadTimeout(TIMEOUT_VALUE);
success.add(p);
} catch(SocketTimeoutException ste) {
System.out.println("Proxy " + p.address().toString() + " timed out.");
}
}
但是他们中的每一个都通过了测试,即使我执行了 TIMEOUT_VALUE = 1;
我做错了什么?感谢您的帮助。
最佳答案
我假设你的问题是你没有从连接中读取任何东西。如果我将 TIMEOUT_VALUE
设置得太低,我会得到一个异常。无论我阅读所有回复还是只阅读一行都不会影响结果时间,我想这是因为我在一个数据包中得到了完整的答案。
这是我使用的测量方法(没有代理):
int TIMEOUT_VALUE = 1000;
try {
URL testUrl = new URL("http://google.com");
StringBuilder answer = new StringBuilder(100000);
long start = System.nanoTime();
URLConnection testConnection = testUrl.openConnection();
testConnection.setConnectTimeout(TIMEOUT_VALUE);
testConnection.setReadTimeout(TIMEOUT_VALUE);
BufferedReader in = new BufferedReader(new InputStreamReader(testConnection.getInputStream()));
String inputLine;
while ((inputLine = in.readLine()) != null) {
answer.append(inputLine);
answer.append("\n");
}
in.close();
long elapsed = System.nanoTime() - start;
System.out.println("Elapsed (ms): " + elapsed / 1000000);
System.out.println("Answer:");
System.out.println(answer);
} catch (SocketTimeoutException e) {
System.out.println("More than " + TIMEOUT_VALUE + " elapsed.");
}
关于java - 如何使用 URLConnection 超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6529733/