先将阿帕奇的commons_io jar包导入到库中
百度搜索直接下载bin包
下载解压后将文件复制到自己创建的文件夹下
然后右键选择Add as Library
添加后就可以开始编写了:
package demo;
import org.apache.commons.io.FileUtils;//刚才导入jar包的引用
import java.io.File;
import java.io.IOException;
import java.net.URL;
//自定义线程继承Thread类
//重写run()方法,编写线程执行体
//创建线程对象,调用start()方法启动线程
public class TTs extends Thread{//继承Tread类
String url;//网图的地址
String name;//保存的文件名
//构造器传参
public TTs(String url,String name) {
this.name=name;
this.url=url;
}
//继承Thread的方法重写,run()方法
@Override
public void run() {
webDownloader webDownloader = new webDownloader();
webDownloader.downLoader(url,name);
System.out.println("下载了文件名为:"+name);
}
public static void main(String[] args) {
//网图随便找,地址复制过来就行
TTs tTs1 = new TTs("http://img.desktx.com/d/file/wallpaper/scenery/20170120/df204ebd7a4829933463e2989deb54c6.jpg","tu1");
TTs tTs2 = new TTs("http://img.desktx.com/d/file/wallpaper/scenery/20170107/080145c3a7460e7fa0369052a11467db.jpg","tu2");
TTs tTs3 = new TTs("https://www.shijuepi.com/uploads/allimg/200918/1-20091Q10415.jpg","tu3");
//将线程启动
tTs1.start();
tTs2.start();
tTs3.start();
}
}
//下载器
class webDownloader{
public void downLoader(String url, String name){
//异常监听
try {
//这里就是刚才导入的jar包中的其中一个方法
FileUtils.copyURLToFile(new URL(url),new File(name));
} catch (IOException e) {
e.printStackTrace();
System.out.println("IO异常,downLoader方法出现问题");
}
}
}
可以点开FileUtils中查看源码:
里面有很多已经写好的方法我们直接使用自己需要的就好了
写完后运行:
图片已经保存过来
但是下载的顺序并不是如我们想那样按顺序来的
而且每次运行的结果顺序都可能不一样
线程的启动顺序与cpu的核有关,假如有三个空闲的核,那么就应该是顺序执行下载。