多个线程启动 ,等待全部执行完毕再搜集数据

前几天在公司的项目上有个同事使用了多线程统计数据,当时出现了一个用户一直使用服务器首次登录信息作为查询信息。找了半天才发现,线程池资源同步了。后面手动将数据set进去的。

等待线程全部执行完毕,这里使用的是减法计数器,也可而已用加法计数器:CyclicBarrier

java 复制代码
package com.quxiao.controller;


import java.util.*;
import java.util.concurrent.*;
import java.util.stream.Collectors;

/**
 * @program: package1
 * @author: quxiao
 * @create: 2023-09-27 15:22
 **/
public class t3 {
    static final ExecutorService service = Executors.newFixedThreadPool(10);

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        CountDownLatch countDownLatch = new CountDownLatch(4);
        FutureTask task1 = new FutureTask<>(new t(2, countDownLatch));
        FutureTask task2 = new FutureTask<>(new t(3, countDownLatch));
        FutureTask task3 = new FutureTask<>(new t(4, countDownLatch));
        FutureTask task4 = new FutureTask<>(new t(5, countDownLatch));
        service.execute(task1);
        service.execute(task2);
        service.execute(task3);
        service.execute(task4);
        countDownLatch.await();
        System.out.println(task1.get());
        System.out.println(task2.get());
        System.out.println(task3.get());
        System.out.println(task4.get());
//        service.shutdown();
    }


    static class t implements Callable<List<Integer>> {
        List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9);
        int sum = 0;
        CountDownLatch countDownLatch;

        public t(int sum, CountDownLatch countDownLatch) {
            this.sum = sum;
            this.countDownLatch = countDownLatch;
        }

        @Override
        public List<Integer> call() throws Exception {
            TimeUnit.SECONDS.sleep(1L);
            List<Integer> returnList = list.stream().filter(x -> x >= sum).collect(Collectors.toList());
            countDownLatch.countDown();
            return returnList;
        }
    }
}

限流操作,限制人数访问,超过预定值就等待:

java 复制代码
package com.quxiao.controller;


import java.util.*;
import java.util.concurrent.*;
import java.util.stream.Collectors;

/**
 * @program: package1
 * @author: quxiao
 * @create: 2023-09-27 15:22
 **/
public class t3 {
    static final ExecutorService service = Executors.newFixedThreadPool(10);

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        Semaphore semaphore = new Semaphore(3);
        for (int i = 0; i < 9; i++) {
            final int t = i;
            new Thread(() -> {
                try {
                    semaphore.acquire();
                    TimeUnit.SECONDS.sleep(5L);
                    System.out.println(Thread.currentThread().getName() + "进来了");
                    System.out.println(Thread.currentThread().getName() + "出去了");
                    System.out.println();
                } catch (InterruptedException e) {
                    throw new RuntimeException(e);
                } finally {
                    semaphore.release();
                }
            }, "" + i).start();
        }
    }
}
相关推荐
空中海1 分钟前
Nacos3: 面试题库
java·面试·职场和发展
摇滚侠1 分钟前
sqlplus “/ as sysdba“ 什么意思
java·数据库·oracle
user_lwl6 分钟前
解决langchain4j+deepseek使用过程中reasoning_contect报错并适配DeepSeekV4
java·后端
架构源启15 分钟前
2026 进阶篇:Spring Boot响应式编程 + Spring AI 1.1.4 流式实战 + Vue前端完整实现(避坑指南)
java·前端·vue.js·人工智能·spring boot·spring·ai编程
csdn2015_15 分钟前
Java List 去重
java·windows·list
skywalk816317 分钟前
CodeArts碰到问题:CodeArts 智能体使用失败,显示:会话创建失败,请稍后重试
开发语言·python
pqq的迷弟19 分钟前
多租户实现方案
java·多租户
随风,奔跑21 分钟前
Mybatis-Plus学习笔记
java·笔记·学习·mybatis
用户2986985301422 分钟前
Java 实战:将 Markdown 文档转换为 Word 与 PDF
java·后端
optimistic_chen24 分钟前
【AI Agent 全栈开发】提示词技巧(prompt)
java·人工智能·ai·prompt·agent