我有以下代码可下载网页:

HttpURLConnection connection;

private String downloadContent() {
    InputStream content;
    Source parser;
    try {
        content = connection.getInputStream(); //<--here is the download
        parser = new Source(content);
        content.close();
        return parser.toString();
    } catch (Exception e) {
        return null;
    }
}

在进行下载时,我尝试获取已下载数据的数量,如果达到限制,我将停止下载,但找不到找到该方法的方法。如果有人知道该怎么做,请告诉我。

现在,我想限制下载时间。示例:如果下载通过20秒,我将停止它。我要这样做是因为我的程序是一个网络爬虫,如果出现错误,它将开始下载一个大文件,它将卡在下载文件中,而不是我不想这样做,因此欢迎按大小过滤下载,但我不知道,过滤时间可以避免此问题。

最佳答案

实现此目的的正确方法如下:

public class TimeOut {

    public static class MyJob implements Callable<String> {

        @Override
        public String call() throws Exception {
            // Do something
            return "result";
        }

    }

    public static void main(String[] args) {

        Future<String> control
                = Executors.newSingleThreadExecutor().submit(new MyJob());

        try {

            String result = control.get(5, TimeUnit.SECONDS);

        } catch (TimeoutException ex) {

            // 5 seconds expired, we cancel the job !!!
            control.cancel(true);

        }
        catch (InterruptedException ex) {

        } catch (ExecutionException ex) {

        }

    }

}

09-10 00:26
查看更多