Java中多线程下载图片并压缩能提高效率吗

作者:马男波杰克 时间:2023-08-06 07:40:10 

目录
  • 前言

  • 实现思路

  • 实测

前言

需求 导出Excel:本身以为是一个简单得导出,但是每行得记录文件中有一列为图片url,需要下载所有记录行对应得图片,然后压缩整个文件夹。

Java中多线程下载图片并压缩能提高效率吗

这里只做4.5.得代码讲解描述,其它也没什么好说得,话不多说上代码.

实现思路

多线程实现使用了线程池,Jdk1.8并发包下的CompletableFuture

第一步:得到基础数值


       // 线程数
       Integer threadNum = 10;
       // 每条线程需要处理的图片数  
       int dataNum = imageInfoVos.size() / threadNum;
       // 写入线程数
       List<Integer> threadS = new ArrayList<>();
       for(int i=0; i<threadNum; i++){
               threadS.add(i);
       }

首先我们保存了需要下载的图片的Url列表,多线程的方式下载我们需要保证每个线程下载的图片不会重复,因此我们需要根据规则来切割保存Url列表的集合,从而保证每个线程下载属于自己的任务,上代码:


// 接上文代码
threadS.stream().map(item -> CompletableFuture.runAsync(() ->{
               List<Image> theadItem = imageInfoVos.subList(dataNum * item,(item+1)==threadNum?imageInfoVos.size():Math.min(dataNum * (item + 1 ), imageInfoVos.size()));
                       threadDownPic(theadItem,item,dirName);
           },threadPoolTaskExecutor)).collect(Collectors.toList()).forEach(item ->{
               try {
                   item.get();
               }catch (Exception e){
                   log.error("============  多线程down执行等待异常 msg:{} =============", e.getMessage());
               }
   });

这里进行拆分讲解

使用CompletableFuture.runAsync 走异步方式,遍历item

如item=10,也就是线程数为10,则直接执行10次(有线程池的前提下)


// 使用CompletableFuture.runAsync 走异步方式,遍历item
// 如item=10,也就是线程数为10,则直接执行10次(有线程池的前提下)
threadS.stream().map(item -> CompletableFuture.runAsync(() ->{

规则:根据item数值通过sublist 从开始到结束,截取对应线程所需要下载的Url列表

例:dataNum为每个线程需要完成的下载数如上文 dataNum为100时

如:item=0 dataNum* item(0) =0,Math.min(dataNum * (item + 1 )=100

(item+1)==threadNum?imageInfoVos.size() 此次是为了保证最后一个线程处理最后不足的图片

根据如上规则即可得到每个线程需要下载的图片Url保证不会重复


  // 根据item数值通过sublist 从开始到结束,截取对应线程所需要下载的Url列表
  // 例:dataNum为每个线程需要完成的下载数如上文 dataNum为100时
  // 如:item=0 dataNum* item(0) =0,Math.min(dataNum * (item + 1 )=100
  // 根据如上规则即可得到每个线程需要下载的图片Url保证不会重复
  // (item+1)==threadNum?imageInfoVos.size() 此次是为了保证最后一个线程处理最后不足的图片
  List<ImageInfoVo> theadItem = imageInfoVos.subList(dataNum * item,(item+1)==threadNum?imageInfoVos.size():Math.min(dataNum * (item + 1 ), imageInfoVos.size()));
  // theadItem:图片Url  item:所属下标  dirName:写入路径url
  threadDownPic(theadItem,item,dirName);

由于执行的异步方式,此处是为了线程池中所有线程都结束才能往下走,执行压缩文件步骤,这里提一嘴,如果没有手动赋予线程池,CompletableFuture默认使用ForkJoinPool.commonPool,会根据电脑核心数来指定,
比如:我本机未指定就是7个线程,执行方法时,会执行完前面7个线程任务,才会继续创建3个线程继续执行后续未完成的


  },threadPoolTaskExecutor)).collect(Collectors.toList()).forEach(item ->{
               try {
                   item.get();
               }catch (Exception e){
                   log.error("============  多线程down执行等待异常 msg:{} =============", e.getMessage());
               }
           });

实测

主要代码也写完了,这种方式真的能提高效率吗?下面我贴几张测试图来说明

Java中多线程下载图片并压缩能提高效率吗

其实这种方式并没有显著的提高效率,当然这是我本机环境测试的。

效率是由网速决定,而不是由本机Cpu和io决定,比如10M带宽,一个线程一个一个顺序下载,但速度是10M,10个线程,可能每个线程的速度是1M,结果没有什么两样。

相对于网速,多线程带来的cpu以及io节省的时间几乎可以忽略,瓶颈还是在网速.

来源:https://juejin.cn/post/6976454072685559822

标签:Java,多线程,下载
0
投稿

猜你喜欢

  • Spring Boot启动过程全面解析(三)

    2023-09-13 13:16:39
  • Java中方法的重写与成员变量的隐藏

    2023-06-01 01:35:55
  • C#实现控制Windows系统关机、重启和注销的方法

    2023-07-24 17:15:05
  • C++实现LeetCode(5.最长回文子串)

    2023-07-03 06:07:13
  • C# 给PPT中的图表添加趋势线的方法

    2022-02-27 10:18:40
  • 关于C#中yield return用法的思考

    2021-11-30 14:05:40
  • Android viewpager 3D画廊的实现方法

    2021-05-28 21:19:27
  • es(elasticsearch)整合SpringCloud(SpringBoot)搭建教程详解

    2023-12-06 07:34:14
  • Java中的同步与异步详细介绍

    2023-06-23 00:42:08
  • Java 获取网站图片的示例代码

    2022-03-11 14:52:44
  • Android开发之DialogFragment用法实例总结

    2023-08-30 13:20:21
  • Android模拟实现支付宝蚂蚁森林效果

    2023-03-15 05:07:38
  • 关于JAVA11中图片与BASE64相互转换的实现

    2022-12-06 06:44:11
  • WPF+SkiaSharp实现自绘弹幕效果

    2022-09-30 09:52:38
  • Java main 方法面试题的详细整理

    2023-11-24 23:53:30
  • springboot项目配置多个kafka的示例代码

    2023-11-23 23:15:29
  • SpringMVC之@requestBody的作用及说明

    2022-06-08 12:35:04
  • java面试try-with-resources问题解答

    2023-09-03 15:08:01
  • 通过实例解析spring环绕通知原理及用法

    2022-12-26 23:33:20
  • 解决Android屏幕四周闪现红框的问题

    2023-09-03 19:17:01
  • asp之家 软件编程 m.aspxhome.com