多线程下载文件

平时开发中有时会用到文件下载,为了提高文件的下载速率,采用多线程下载能够达到事半功倍的效果:

package test;

/**

* 文件下载类

* @author luweicheng

*

*/

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.InputStream;

import java.io.RandomAccessFile;

import java.net.HttpURLConnection;

import java.net.URL;

import java.net.URLConnection;

public class DownFile {

private URL fileUrl;// 文件下载路径

private int threadCount;// 文件下载的线程数

private int startPos;// 每个线程下载文件的开始位置

private int size;// 每个线程下载文件的长度

private int fileLength;// 文件总程度

private String pathName;// 下载的文件路径(包含文件名)

private Downthread[] tDownthreads;// 线程数组

public DownFile(URL url, int threadCount, String pathName) throws IOException {

fileUrl = url;

this.threadCount = threadCount;

this.pathName = pathName;

init();

}

/**

* 初始化

*

* @throws IOException

*/

private void init() throws IOException {

tDownthreads = new Downthread[threadCount];

HttpURLConnection conn = (HttpURLConnection) fileUrl.openConnection();

conn.setConnectTimeout(5000);

conn.setRequestMethod("GET");

conn.setRequestProperty("connection", "keep-alive");

fileLength = conn.getContentLength();

System.out.println("文件长度" + fileLength);

size = fileLength / threadCount;

System.out.println("每个下载量==" + size);

conn.disconnect();// 断开链接

}

public URL getFileUrl() {

return fileUrl;

}

public int getThreadCount() {

return this.threadCount;

}

/**

* 开始下载

*/

public void startDown() {

for (int i = 0; i < threadCount; i++) {

try {

RandomAccessFile raFile = new RandomAccessFile(pathName, "rw");

tDownthreads[i] = new Downthread(i * size, raFile, i);

tDownthreads[i].start();

} catch (FileNotFoundException e) {

e.printStackTrace();

}

}

}

/**

* 下载线程类

*

* @author luweicheng

*

*/

class Downthread extends Thread {

private int startPos;// 开始的位置

private InputStream is;

private RandomAccessFile raFile;

private int length;// 下载的文件长度

private int flag;// 线程标志

public Downthread(int startPos, RandomAccessFile raFile, int i) {

this.startPos = startPos;

this.raFile = raFile;

flag = i;

}

@Override

public void run() {

try {

HttpURLConnection connection = (HttpURLConnection) fileUrl.openConnection();

connection.setRequestMethod("GET");

connection.setRequestProperty("connection", "keep-alive");

connection.setConnectTimeout(5 * 1000);

is = connection.getInputStream();

is.skip(startPos);

raFile.seek(startPos);

byte[] buf = new byte[8 * 1024];

int hasread = 0;// 读出的字节数

// 将位置在 startPos - startPos 位置的数据读出写入

while (length < size && (hasread = is.read(buf)) != -1) {

raFile.write(buf, 0, hasread);

length += hasread;

System.out.println("*****线程" + flag + "下载了*********" + length);

}

System.out.println("*******线程" + flag + "下载完成*********");

} catch (IOException e) {

} finally {

try {

is.close();

raFile.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

}

}

效果展示:

详细配置信息可以参考这篇文章:

http://blog.ncmem.com/wordpress/2019/08/28/java%e6%89%b9%e9%87%8f%e4%b8%8b%e8%bd%bd/

java多线程批量下载文件的更多相关文章

  1. java多线程批量读取文件(七)

    新公司入职一个多月了,至今没有事情可以做,十来个新同事都一样抓狂,所以大家都自己学习一些新东西,我最近在看zookeeper,感觉蛮不错的,和微服务的zuul以及eureka功能类似,只是代码复杂了一 ...

  2. Java多线程断点下载文件

    Java实现断点续传+多线程下载 如下代码所示,每一步都有注解 思路: 通过URL连接到服务器上要下载的文件,得到文件的大小: 算出每条线程下载的开始位置和结束位置,例如,有两条线程下载100Byte ...

  3. java+web+批量下载文件

    JavaWeb 文件下载功能 文件下载的实质就是文件拷贝,将文件从服务器端拷贝到浏览器端,所以文件下载需要IO技术将服务器端的文件读取到,然后写到response缓冲区中,然后再下载到个人客户端. 1 ...

  4. java多线程批量读取文件( 八)--读写分离

    package com.net.thread.future; import java.io.BufferedReader; import java.io.BufferedWriter; import ...

  5. java/resteasy批量下载存储在阿里云OSS上的文件,并打包压缩

    现在需要从oss上面批量下载文件并压缩打包,搜了很多相关博客,均是缺胳膊少腿,要么是和官网说法不一,要么就压缩包工具类不给出 官方API https://help.aliyun.com/documen ...

  6. Java批量下载文件并zip打包

    客户需求:列表勾选需要的信息,点击批量下载文件的功能.这里分享下我们系统的解决方案:先生成要下载的文件,然后将其进行压缩,生成zip压缩文件,然后使用浏览器的下载功能即可完成批量下载的需求.以下是zi ...

  7. java批量下载文件为zip包

    批量下载文件为zip包的工具类 package com.meeno.trainsys.util; import javax.servlet.http.HttpServletRequest; impor ...

  8. Java多线程的下载器(1)

    实现了一个基于Java多线程的下载器,可提供的功能有: 1. 对文件使用多线程下载,并显示每时刻的下载速度. 2. 对多个下载进行管理,包括线程调度,内存管理等. 一:单个文件下载的管理 1. 单文件 ...

  9. python多线程批量下载远程图片

    python多线程使用场景:多线程采集, 以及性能测试等 . 数据库驱动类-简单封装下 mysqlDriver.py #!/usr/bin/python3 #-*- coding: utf-8 -*- ...

随机推荐

  1. k8s-高可用架构设计

    docker的私有仓库harbor.容器化kubernetes部分组建.使用阿里云日志服务收集日志. 部署完成后,你将理解系统各组件的交互原理,进而能快速解决实际问题,所以本文档主要适合于那些有一定k ...

  2. java8 List对象集合去重

    //测试数据 WaterMeter w0 = new WaterMeter(); WaterMeter w1 = new WaterMeter(); WaterMeter w2 = new Water ...

  3. 怎样禁止 html 中 <textarea> 标签可以拉伸改变大小 ?

    1. 一般来说, 使用 <textarea> 这个标签都会禁用掉它的这个默认属性, 不然可能会被用户玩儿坏, 而且也不利于其他元素的展示, 使用到的属性是 resize , 改为 none ...

  4. mybatis中collection子查询注入参数为null

    具体实现参照网上,但是可能遇到注入参数为null的情况,经过查阅及自己测试记录一下: 子查询的参数中,有<if test="">之类,需要指定别名,通过 http:// ...

  5. 阿里云语音合成(汉语英语)带UI界面的小程序(python)

    一,项目说明 将汉文转汉语.英文转英语,同时又有逗号<###English###>,<,,,>和句号<...>标志符用于文件处理.其中英文包含在### 英文 ### ...

  6. vbs 简单文件操作

    Dim fso, MyFile, fldSet fso = CreateObject("Scripting.FileSystemObject")Set fld = fso.crea ...

  7. 查找和杀掉占用GPU显存的进程

    用只有2个G的显卡跑数据就需要在训练之前先把无关进程杀掉,防止跑到一半显存满了 nvidia-smi:显示当前GPU中的线程 kill -9 PID:输入PID以结束线程

  8. 养成一个SQL好习惯

    要知道sql语句,我想我们有必要知道sqlserver查询分析器怎么执行我么sql语句的,我么很多人会看执行计划,或者用profile来监视和调优查询语句或者存储过程慢的原因,但是如果我们知道查询分析 ...

  9. centos7安装配置NFS文件共享存储

    一,环境介绍    本实验使用了两台centos7虚拟机,其中         服务器:192.168.1.188    客户端:192.168.1.189 二,实验步骤    192.168.1.1 ...

  10. 微信小程序onLoad、onShow、onHide、onUnload区别

    onLoad:页面第一次加载时触发,从跳转页面返回时不能触发,可以传递参数 onShow:页面显示或从后台跳回小程序时显示此页面时触发,从跳转页面返回时触发,不能传递参数 onHide:页面隐藏,例如 ...