使用CountDownLatch怎么实现一个并发框架
发表于:2025-01-31 作者:千家信息网编辑
千家信息网最后更新 2025年01月31日,本篇文章给大家分享的是有关使用CountDownLatch怎么实现一个并发框架,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。目录结构pa
千家信息网最后更新 2025年01月31日使用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 ListexecuteUnits = 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安全错误
数据库的锁怎样保障安全
信息与网络技术基础测试
安徽立体化软件开发怎么样
秦皇岛网络技术有限公司
银行数据库有黑客侵入吗
广州视频安防软件开发费用
江苏住银所互联网科技
千纸鹤网络技术有限公司
宝德网络技术有限公司江西
魔兽世界新出服务器
搭建存储服务器
2021河南省高校网络安全
服务器手机版
软件开发应该注意哪些问题
中国8月进出口数据库
陕西服务器批发
2005数据库质疑
互联网科技常用词汇
方舟在自己服务器开修改器
谷歌服务器优化工具
计算机网络技术人才市场分析
中国年龄大的软件开发者
数据库数据文献引用格式
超凡先锋不同服务器能联机吗
我的世界布吉岛服务器怎么加好友
用户数据分析有利网络安全
数据库设计活的
数据库多表查询格式
腾讯云服务器怎么连接电视
支付宝网络技术信息技术
超微服务器兼容操作系统