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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何将本地文件传到虚拟机linux_怎么把文件放到虚拟机里的系统里

    如何将本地文件传到虚拟机linux_怎么把文件放到虚拟机里的系统里一、使用FileZilla上传文件1.启动虚拟机,打开Linux终端,输入ifconfig命令查看IP地址IP地址为192.168.59.62.打开FileZilla,输入IP地址,用户名,密码,端口号,点击快速连接连接成功后,左边为本机资源目录,右边为虚拟机目录,左边选中文件,右键选择上传,即可上传成功二、使用SecureCRT或Xshell上…

    2022年8月22日
    191
  • 排序算法最坏情况下的比较次数怎么算_选择排序最坏情况

    排序算法最坏情况下的比较次数怎么算_选择排序最坏情况在最坏情况下,冒泡排序、直接插入排序与简单选择排序法均需要比较n(n-1)/2次。希尔排序需要比较n^1.5次,堆排序需要比较的次数最少,为nlog2n。

    2022年8月23日
    7
  • DVWA安装以及模块使用教程(一)

    DVWA安装以及模块使用教程(一)一 DVWA 介绍 DVWA DamnVulnerab 是 randomstorm 的一个开源项目 一个用来进行安全脆弱性鉴定的 PHP MySQLWeb 应用 旨在为安全专业人员测试自己的专业技能和工具提供合法的环境 帮助 web 开发者更好的理解 web 应用安全防范的过程 DVWA 共有十个模块 分别是 1 BruteForce 密码激活成功教程 2 CommandInjec 命令行注入 3 CSRF 跨站请求伪造 4 FileInclusio 文件包含 5 F

    2025年8月9日
    7
  • java中static归纳总结

    java中static归纳总结在《Java编程思想》P86页有这样一段话:  “static方法就是没有this的方法。在static方法内部不能调用非静态方法,反过来是可以的。而且可以在没有创建任何对象的前提下,仅仅通过类本身来调用static方法。这实际上正是static方法的主要用途。”  这段话虽然只是说明了static方法的特殊之处,但是可以看出static关键字的基本作用,简而言之,一句话来描述就是:  方便在没有…

    2022年7月17日
    19
  • 保护ASP.NET 应用免受 CSRF 攻击

    保护ASP.NET 应用免受 CSRF 攻击

    2021年9月11日
    58

发表回复

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

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