使用CountDownLatch怎么实现一个并发框架
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,本篇文章给大家分享的是有关使用CountDownLatch怎么实现一个并发框架,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。目录结构pa
千家信息网最后更新 2025年12月04日使用CountDownLatch怎么实现一个并发框架
本篇文章给大家分享的是有关使用CountDownLatch怎么实现一个并发框架,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
目录结构
package com.**.**.base.support.executor;import lombok.NoArgsConstructor;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.springframework.util.Assert;import java.util.ArrayList;import java.util.List;import java.util.concurrent.CountDownLatch;import java.util.concurrent.Executor;import java.util.concurrent.Executors;import java.util.stream.Collectors;/** * @Author lbm * @Date 2019/10/9 10:32 上午 * @Description YJ执行器 **/@NoArgsConstructorpublic class YjExecutor {private static final Log log = LogFactory.getLog(YjExecutor.class);private static final int FIRST_RETURN = 1;private CountDownLatch latch;private List executeUnits = new ArrayList<>();private Executor pool = Executors.newFixedThreadPool(10);public static YjExecutor build() {return new YjExecutor(); }public YjExecutor add(ExecuteUnit paramUnit) { paramCheck(paramUnit);executeUnits.add(paramUnit);return this; }public YjExecutor addAll(List paramUnits) { paramCheck(paramUnits);this.executeUnits.addAll(paramUnits);return this; }/** * 第一个执行完返回 * * @return 执行结果 */ public ReturnT firstPriorityReturn() {this.latch = new CountDownLatch(FIRST_RETURN); List results = this.submit();return results.stream() .filter(res -> res != null && res.getRes() != null) .findFirst() .orElse(null); }/** * 所有执行完才返回 * * @return 执行结果 */ public List allReturn() {this.latch = new CountDownLatch(executeUnits.size());return submit(); }/** * 参数校验 * * @param paramUnits 参数列表 */ private void paramCheck(List paramUnits) { Assert.notNull(paramUnits, "Argument can not be null !!");for (ExecuteUnit paramUnit : paramUnits) { paramCheck(paramUnit); } }/** * 参数校验 * * @param paramUnit 单个参数 */ private void paramCheck(ExecuteUnit paramUnit) { Assert.notNull(paramUnit, "Argument can not be null !!"); Assert.notNull(paramUnit.getFunc(), "Argument function can not be null !!"); }/** * 执行 */ private void execute() {try {for (ExecuteUnit executeUnit : executeUnits) {pool.execute(executeUnit.getYjRunner()); }latch.await(); } catch (Exception e) {log.error("execute error {}", e); } }/** * 提交 * * @return 返回执行结果 */ private List submit() { buildExecuteUnit(); execute();return executeUnits.stream() .map(ExecuteUnit::getResult) .collect(Collectors.toList()); }/** * 创建执行单元 */ private void buildExecuteUnit() {for (ExecuteUnit executeUnit : executeUnits) { executeUnit.setYjRunner(executeUnit.yjRunnerBuild(latch)); } }} package com.**.**.base.support.executor;import lombok.Builder;import lombok.Data;/** * @Author lbm * @Date 2019/10/9 10:10 上午 * @Description 执行结果 **/@Data@Builderpublic class ReturnT{private ExecuteEnum resCode;private R res;}
package com.**.**.base.support.executor;import lombok.AllArgsConstructor;import lombok.Builder;import lombok.Data;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import java.util.concurrent.CountDownLatch;import java.util.function.Function;/** * @Author lbm * @Date 2019/10/9 7:33 下午 * @Description 执行单元 **/@Data@Builderpublic class ExecuteUnit{private static Logger log = LoggerFactory.getLogger(ExecuteUnit.class);private Function func;private T param;private ReturnT result;private YjRunner yjRunner;public YjRunner yjRunnerBuild(CountDownLatch latch) {return new YjRunner(latch, this); }@AllArgsConstructor public static class YjRunner implements Runnable {private CountDownLatch latch;private ExecuteUnit executeUnit;@Override public void run() { ReturnT returnT = ReturnT.builder() .resCode(ExecuteEnum.SUCCESS) .build();try { Object res = executeUnit.getFunc().apply(executeUnit.getParam()); returnT.setRes(res); } catch (Exception e) {log.error("param: {} execute error: {}", executeUnit.getParam(), e); returnT.setResCode(ExecuteEnum.FAIL); } finally {executeUnit.setResult(returnT);this.latch.countDown(); } } }}
package com.**.**.base.support.executor;/** * @Author lbm * @Date 2019/10/9 2:54 下午 * @Description 执行结果 **/public enum ExecuteEnum {/** * 执行结果 */ SUCCESS,FAIL;}package com.**.**.**.serviceTest;import com.alibaba.fastjson.JSONObject;import com.**.**.base.support.executor.ExecuteUnit;import com.**.**.base.support.executor.ReturnT;import com.**.**.base.support.executor.YjExecutor;import com.**.**.api.domain.SysUser;import com.**.**.server.BaseTest;import org.junit.Test;import org.slf4j.Logger;import org.slf4j.LoggerFactory;import java.util.ArrayList;import java.util.List;import java.util.function.Function;/** * @Author lbm * @Date 2019/10/9 10:45 上午 * @Description yj执行器测试 **/public class ExecutorTest extends BaseTest {private Logger logger = LoggerFactory.getLogger(this.getClass());private Function以上就是使用CountDownLatch怎么实现一个并发框架,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。
结果
参数
框架
单元
更多
知识
篇文章
执行器
实用
单个
就是
工作会
文章
目录
看吧
知识点
结构
行业
详情
资讯
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
计算机网络安全对国家
软件开发模型作用
我的世界如何在服务器上开材质包
阳明网络安全检查
枣强天气预报软件开发
网络技术和社会就业
学软件开发好学多久
商超软件开发
软件开发难呀
软件开发要考
内燃机网络技术
服务器智能网卡多少钱
中职开设网络安全专业课程设置
斗罗大陆魂师对决豪杰服务器
全国网络安全模型大赛
阿里云专线服务器
武汉网络技术服务
崇阳县疾控中心网络安全
云更新服务器设置
网站服务器5种方式
2021年汉中宣传网络安全
网络安全工作征文1500字
数据库处理流水
等保网络安全产品清单下载
军用网络技术
网络安全竞答实操
新奇软件开发项目
杨浦区数据库卷尺定制联系方式
栾城区应用软件开发服务供应
买卖游戏服务器合法吗