JAVA初学(八):多线程下载多个网页文件

一、题目:

下面的程序可以下载多个网页文件(download方法已写好),请将它改成多线程进行下载,如果可能, 显示计算全部下载完成程序所用的时间(提示:new Date().getTime()可以得到当前时间的毫秒数)。

import java.net.URL;
import java.io.*;
 
class Downloader 
{
    public static void main(String[] args)
        throws Exception
    {
        final URL[] urls = {
            new URL("https://www.pku.edu.cn"),
            new URL("https://www.baidu.com"),
            new URL("https://www.sina.com.cn"),
            new URL("https://www.dstang.com")
        };
        final String[] files = {
            "pku.htm", 
            "baidu.htm",
            "sina.htm", 
            "study.htm",
        };
 
        for(int idx=0; idx<urls.length; idx++){
            try{
                System.out.println( urls[idx] );
                download( urls[idx], files[idx]);
            }catch(Exception ex){
                ex.printStackTrace();
            }
        }
    }
    static void download( URL url, String file)
        throws IOException
    {
        try(InputStream input = url.openStream();
            OutputStream output = new FileOutputStream(file))
        {
            byte[] data = new byte[1024];
            int length;
            while((length=input.read(data))!=-1){
                output.write(data,0,length);
            }
        }
    }
}

二、程序编写(附注释)

/**************************************************************************************
* @多线程练习题
* @作者:IMUHERO
* @时间:2019/2/21
***************************************************************************************/
package Learning;
import java.net.URL;
import java.io.*;

/*
* 类名:Downloader
* 功能:实现多线程下载相应网页
* 完成时间:2019/2/21
* */
class Downloader extends Thread{
    URL url;String file;
     Downloader( URL url, String file){
         this.url=url;
         this.file=file;
         System.out.println( url);
     }

    public void run(){
        java.io.InputStream input = null ;
        java.io.OutputStream output = null ;
        try{

            input =  url.openStream();
            output = new FileOutputStream(file);
            byte[] data = new byte[1024];
            int length;
            try {
                while((length=input.read(data))!=-1){
                    output.write(data,0,length);
                }
            }catch (IOException e1) {
                e1.printStackTrace();
            }
        }catch(IOException e1){
            e1.printStackTrace();
        }

    }

}

class test
{
    public static void main(String[] args)
            throws Exception
    {
        final URL[] urls = {                                    //URL数组,定义网页地址
                new URL("https://www.pku.edu.cn"),
                new URL("https://www.baidu.com"),
                new URL("https://www.sina.com.cn"),
                new URL("https://www.dstang.com")
        };
        final String[] files = {                                //定义网页htm文件名
                "pku.htm",
                "baidu.htm",
                "sina.htm",
                "study.htm",
        };

        Downloader downloader1=new Downloader(urls[0],files[0]);        //启动四个线程
        downloader1.start();
        Downloader downloader2=new Downloader(urls[1],files[1]);
        downloader2.start();
        Downloader downloader3=new Downloader(urls[2],files[2]);
        downloader3.start();
        Downloader downloader4=new Downloader(urls[3],files[3]);
        downloader4.start();
    }

}

三、注:

本文借鉴了:

CSDN作者:石前有座桥的文章:week8多线程

链接:https://blog.csdn.net/lyw_321/article/details/79981323

并且加上自己的思考和修改完善。

1.得到服务器下载文件的大小,然后在本地设置一个临时文件和服务器端文件大小一致 a)获得访问网络地址 b)通过URL对象的openConnection()方法打开连接,返回一个连接对象 c)设置求头 i.setRequestMethod ii.setConnectTimeout iii.setReadTimeout d)判断是否响应成功 e)获取文件长度(getContentLength()) f)随机访问文件的读取与写入RandomAccessFile(file, mode) g)设置临时文件与服务器文件大小一致(setLength()) h)关闭临时文件 2.计算出每个线程下载的大小(开始位置,结束位置) a)计算出每个线程下载的大小 b)for循环,计算出每个线程的开始、结束位置 c)最后一个线程处理 3.每创建好一次就要开启线程下载 a)构造方法 b)通过URL对象的openConnection()方法打开连接,返回一个连接对象 c)设置求头 i.setRequestMethod ii.setConnectTimeout d)判断是否响应成功(206) e)获取每个线程返回的流对象 f)随机访问文件的读取与写入RandomAccessFile(file, mode) g)指定开始位置 h)循环读取 i.保存每个线程下载位置 ii.记录每次下载位置 iii.关闭临时记录位置文件 iv.随机本地文件写入 v.记录已下载大小 i)关闭临时文件 j)关闭输入流 4.为了杀死线程还能继续下载的情况下,从本地文件上读取已经下载文件的开始位置 a)创建保存记录结束位置的文件 b)读取文件 c)将流转换为字符 d)获取记录位置 e)把记录位置赋给开始位置 5.当你的n个线程下载完毕的时候我进行删除记录下载位置的缓存文件 a)线程下载完就减去 b)当没有正在运行的线程时切文件存在时删除文件
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IMUHERO

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值