首页 > 其他分享 >并发跑任务:任一失败任务停下

并发跑任务:任一失败任务停下

时间:2023-10-08 16:49:19浏览次数:28  
标签:Task name add taskList 并发 任务 任一 new String

import java.util.concurrent.*;

public class Main {

    public static void main(String[] args) {
        ExecutorService executorService = Executors.newFixedThreadPool(5);
        List<Callable<String>> taskList = new ArrayList<>();
        taskList.add(new Task("Task 1"));
        taskList.add(new Task("Task 2"));
        taskList.add(new Task("Task 3"));
        //... add more tasks

        try {
            List<Future<String>> futures = executorService.invokeAll(taskList);
            for (Future<String> future : futures) {
                System.out.println(future.get());
            }
        } catch (InterruptedException | ExecutionException e) {
            e.printStackTrace();
        } finally {
            executorService.shutdown(); 
        }
    }

    static class Task implements Callable<String> {
        private final String name;

        public Task(String name) {
            this.name = name;
        }

        @Override
        public String call() throws Exception {
            // 在此处执行任务的逻辑
            System.out.println("Executing task: " + name);
            Thread.sleep(1000);  // 模拟耗时操作
            if (Math.random() > 0.5) {  // 有50%的几率任务成功
                System.out.println("Task " + name + " is successful");
                return name + " is successful";  // 成功返回的结果
            } else {
                throw new RuntimeException("Task " + name + " failed");  // 失败抛出异常
            }
        }
    }
}

标签:Task,name,add,taskList,并发,任务,任一,new,String
From: https://www.cnblogs.com/ArthurHenry/p/17749533.html

相关文章

  • SpringBoot简易任务栏示例
    一、概述现有这样一个需求:前端要求实现类似任务栏的东西(windows电脑的任务栏)。要求:可以向任务栏增加图标、删除图标、给任务栏中的图标排序以及加载任务栏图标列表参考样例图:规律图: 思路:(这里假设任务栏图标列表本身就是一个有序的集合,排序规则按照sort正向排序)......
  • synchronized解决并发问题实践
    场景一: 场景描述:会议下面可以同时上传多个会议资料,资料是有顺序的,也就是有序号order,上传后可以上下移动资料顺序,移动资料顺序是靠改变order来实现的,这就需要保证每个资料的顺序不能一样,上传一个资料调一次上传接口,同时上传10个资料会同时调10次上传接口。上传接口逻辑是先查当......
  • 磁盘清理、大文件查找、磁盘扩容、定时任务
    磁盘清理 rm-rf 脚本:#!/bin/shcd/;find-name"java_pid*.hprof"-execrm-rf{}\;或者rm-rf/java_pid*\.hprof大文件查找查找并列出当前目录中最大的目录:du-h--max-depth=1查找当前目录中所有文件的大小du-sh*   磁盘扩容 一、      增加......
  • 升讯威在线客服系统的并发高性能数据处理技术:对接百度自动翻译
    我在业余时间开发维护了一款免费开源的升讯威在线客服系统,也收获了许多用户。对我来说,只要能获得用户的认可,就是我最大的动力。最近客服系统成功经受住了客户现场组织的压力测试,获得了客户的认可。客户组织多名客服上线后,所有员工同一时间打开访客页面疯狂不停的给在线客服发消......
  • 多线程抢票,并发问题
    Tread类中:currentThread().getName()可以拿到自己的名字sleep() 模拟延时 一、一样的创建一个线程类来实现Runnable接口并且重写run方法 这里定义了Num来代表票数 run方法来实现抢票 如果票没了就break退出循环并且运用了Thread类中的两个方法开头有介绍二、实......
  • 任务执行的洋葱模型
    classTaskUtils{constructor(){this.currentIndex=0this.tasks=[]this._isRunning=falsethis._next=async()=>{this.currentIndex++;awaitthis._runTask();}}addTa......
  • Django实战项目-学习任务系统-用户登录
    第一步:先创建一个Django应用程序框架代码1,先创建一个Django项目django-adminstartprojectmysite将创建一个目录,其布局如下:mysite/manage.pymysite/__init__.pysettings.pyurls.pyasgi.pywsgi.py2,再创建一个Dja......
  • 重新编译kyuubi-1.6.1版本使其提交flink sql流式任务时不阻塞
    kyuubi-1.6.1版本对于flinksql的支持不是很好,在提交流式任务时会阻塞进程,为了修复这个缺陷,需要修改源代码并重新编译待编译的kyuubi版本:kyuubi-1.6.1-incubating适配的flink版本:flink-1.14.41、下载kyuubi-1.6.1-incubating版本的源代码,并导入IDEA中gitclone-bv1.6.1-incu......
  • 一个多线程任务流程控制
    importthreadingclassQue_test:def__init__(self):#创建条件变量和计数器self.cv=threading.Condition()self.counter=1deffirst(self):withself.cv:print('first')self.counter+=1......
  • 解决DOS攻击生产案例:根据web日志或者或者网络连接数,监控当某个IP 并发连接数或者短时
    方法一:在awk中已经判断好并发连接数量的ip地址,传给whileread执行防火墙规则封掉对应的ip。root@centos8~]#catddos.sh#!/bin/bashss-nt|awk-F '[:]+''/ESTAB/{ip[$(NF-2)]++}END{for(iinip)if(ip[i]>100)printi}'|awk-F']''{print$1}'|whilere......