forkjoin使用_forkjoin与线程池区别

forkjoin使用_forkjoin与线程池区别ForkJoinPoolinfoForkJoinPool=newForkJoinPool(Runtime.getRuntime().availableProcessors()*2);ForkJoinTask<Map<Long,InfoVO>>forkJoinTask=ThreadPoolManage.infoForkJoinPool.submit(newPriceTask(skuIds,0,skuIds.size(),infoSoaService));

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺



ForkJoinPool infoForkJoinPool = new ForkJoinPool(Runtime.getRuntime().availableProcessors() * 2);

ForkJoinTask<Map<Long,InfoVO>> forkJoinTask = ThreadPoolManage.infoForkJoinPool.submit(new PriceTask(skuIds, 0, skuIds.size(),infoSoaService));

Map<Long,InfoVO> infoVOMap = forkJoinTask.join();


 /** * 多任务查询 */
    public class PriceTask extends RecursiveTask<Map<Long,InfoVO>> { 
   
        /** * sku集合 */
        private Set<Long> skuIds;
        /** * */
        private InfoSoaService infoSoaService;
        /** * 开始 */
        private int start;
        /** * 最大 */
        private int end;
        /** * 单次最多查询sku数量 */
        static final int THRESHOLD = 20;

        public PriceTask(Set<Long> skuIds, int start, int end,InfoSoaService infoSoaService) { 
   
            this.skuIds = skuIds;
            this.start = start;
            this.end = end;
            thisinfoSoaService = infoSoaService;
        }

        @Override
        protected Map<Long, InfoVO> compute() { 
   
            if (end - start <= THRESHOLD) { 
   
                List<Long> skuList = new ArrayList<>(skuIds);
                Response<Map<Long, InfoVO>> bySkuIds = infoSoaService.getInfoBySkuIds(buildCaller(), new HashSet<>(skuList.subList(start, end)));
                return new HashMap<>(bySkuIds.getData());
            }
            int middle = (end + start) / 2;
            PriceTask left = new PriceTask(skuIds, start, middle, infoSoaService);
            PriceTask right = new PriceTask(skuIds, middle, end, infoSoaService);
            invokeAll(left, right);
            Map<Long,InfoVO> resultMap = new HashMap<>();
            Map<Long, InfoVO> infoVOLeftMap = left.join();
            Map<Long, InfoVO> infoVORightMap = right.join();
            resultMap.putAll(infoVOLeftMap);
            resultMap.putAll(infoVORightMap);
            return resultMap;
        }
    }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/191302.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python 字符串方法isdigit()

    python 字符串方法isdigit()

    2021年10月22日
    76
  • c++ map与unordered_map区别及使用

    c++ map与unordered_map区别及使用转自:https://blog.csdn.net/BillCYJ/article/details/78985895需要引入的头文件不同map:#include&lt;map&gt;unordered_map:#include&lt;unordered_map&gt;内部实现机理不同map:map内部实现了一个红黑树(红黑树是非严格平衡二叉搜索树,而AVL是严格平衡二…

    2022年6月29日
    20
  • lcd电子时钟怎么调_keil液晶显示程序

    lcd电子时钟怎么调_keil液晶显示程序第11周上机程序-LCD12864显示-操作示范结果展示取模软件软件图片软件下载百度网盘下载钉钉群下载软件使用方法(文字取模)软件使用方法(字符取模)程序修改导入原本程序修改原程序修改文字修改学号完整程序结果展示取模软件软件图片软件下载百度网盘下载链接:link.提取码:houh钉钉群下载软件使用方法(文字取模)点击C51后字符便会自动生成。保存为记事本形式,如下所示软件使用方法(字符取模)一样的操作,输入学号,生成16进制数组,保存于桌面即可。程

    2022年10月8日
    0
  • Cannot resolve jdk.tools:jdk.tools:1.7

    Cannot resolve jdk.tools:jdk.tools:1.7

    2021年5月15日
    231
  • linux 查看端口占用情况

    linux 查看端口占用情况之前查询端口是否被占用一直搞不明白,问了好多人,终于搞懂了,现在总结下:1.netstat-anp|grep端口号如下,我以3306为例,netstat-anp|grep3306(此处备注下,我是以普通用户操作,故加上了sudo,如果是以root用户操作,不用加sudo即可查看),如下图1:…

    2022年6月21日
    27
  • 协同过滤推荐算法介绍(协同过滤算法的简单实现)

       根据协同过滤推荐算法的依据不同,可以将算法分为基于用户的、基于项目的和基于模型的。

    2022年4月16日
    61

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号