为了账号安全,请及时绑定邮箱和手机立即绑定

点击暂停后,进度值会超过100%

如果一次性下载完apk文件,则进度值正常

如果中间有过暂停,则下载进度值会超过100%,但是文件下载下来是正常的,怀疑是暂停保存各个线程已完成进度的时候有问题。

哪位仁兄能看出问题所在:

@Override

public void run() {

// 设置线程下载位置

try {

URL url = new URL(threadInfo.getUrl());

con = (HttpURLConnection) url.openConnection();

con.setReadTimeout(5000);

con.setRequestMethod("GET");


// 设置下载位置

int start = threadInfo.getStart() + threadInfo.getProgress();

con.setRequestProperty("Range", "bytes=" + start + "-"

+ threadInfo.getEnd());


// 文件写入路径

String path = File.separator + Constants.FILE_DOWNLOAD

+ File.separator + fileInfo.getFileName();

File downFile = FileUtils.getAppFile(context, path);


raf = new RandomAccessFile(downFile, "rwd");

// 在读写的时候跳过设置好的字节数,从下一个字节数开始读写

raf.seek(start);


Intent intent = new Intent(DownService.ACTION_UPDATE);

progress += threadInfo.getProgress();// 线程完成进度


// 开始下载

if (HttpStatus.SC_PARTIAL_CONTENT == con.getResponseCode()) {

// 读取数据

is = con.getInputStream();

byte[] buffer = new byte[1024 * 4];

int len = -1;

long time = System.currentTimeMillis();

while ((len = is.read(buffer)) != -1) {

// 写入文件

raf.write(buffer, 0, len);


// 整个文件的完成进度

progress += len;


// 当前线程完成的进度

threadInfo.setProgress(threadInfo.getProgress() + len);


// 每隔500毫秒发送一次广播刷新进度条

if (System.currentTimeMillis() - time > 1000) {

time = System.currentTimeMillis();


int percent = (int) (progress * 100 / fileInfo

.getLength());


String str = fileInfo.getFileName() + " ";

str += threadInfo.getThreadId();

str += " progress:" + progress;

str += " tp:" + threadInfo.getProgress();

str += " 差:" + (fileInfo.getLength() - progress);

str += " percent:" + percent;

LogUtils.i(str);


intent.putExtra(PROGRESS, percent);

intent.putExtra(FILE_ID, fileInfo.getId());


// 发送广播更新进度条

context.sendBroadcast(intent);

}


// 下载暂停时,保存下载进度

if (isPause) {

isRuning = false;


String str = fileInfo.getFileName() + " ";

str += threadInfo.getThreadId();

str += " progress:" + progress;

str += " tp:" + threadInfo.getProgress();

str += " 差:" + (fileInfo.getLength() - progress);

str += " pause ";

LogUtils.i(str);


dao.updateThread(threadInfo);

return;

}

}


// 标识当前线程执行完毕

isFinish = true;


// 检查下载任务是否执行完毕

checkAllThreadFinished();

}

} catch (Exception e) {

e.printStackTrace();

} finally {

try {

if (is != null) {

is.close();

}

if (raf != null) {

raf.close();

}

if (con != null) {

con.disconnect();

}

} catch (Exception e2) {

e2.printStackTrace();

}

}

}


正在回答

举报

0/150
提交
取消
Android-Service系列之断点续传下载
  • 参与学习       20443    人
  • 解答问题       87    个

想升职加薪么?本章课程你值得拥有,满满的干货,学起来吧

进入课程

点击暂停后,进度值会超过100%

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信