在整个思路上要调整一下 1、会有很多线程给一个队列上添加任务 2、有一个或者多个线程逐个执行队列的任务 考虑一下几点: 1、没有任务时,队列执行线程处于等待状态 2、添加任务时,激活队列执行线程,全部run起来,首先抢到任务的执行,其他全部wait 给个小例子吧 package org;import java.util.LinkedList;import java.util.List;public class Queues { public static List<Task> queue = new LinkedList<Task>(); /** * 假如 参数o 为任务 * @param o */ public static void add (Task t){ synchronized (Queues.queue) { Queues.queue.add(t); //添加任务 Queues.queue.notifyAll();//激活该队列对应的执行线程,全部Run起来 } } static class Task{ public void test(){ System.out.println("我被执行了"); } }} package org;import java.util.List;public class Exec implements Runnable{ @Override public void run() { while(true){ synchronized (Queues.queue) { while(Queues.queue.isEmpty()){ // try { Queues.queue.wait(); //队列为空时,使线程处于等待状态 } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("wait..."); } Queues.Task t= Queues.queue.remove(0); //得到第一个 t.test(); //执行该任务 System.out.println("end"); } } } public static void main(String[] args) { Exec e = new Exec(); for (int i = 0; i < 2; i++) { new Thread(e).start(); //开始执行时,队列为空,处于等待状态 } //上面开启两个线程执行队列中的任务,那就是先到先得了 //添加一个任务测试 Queues.Task t =new Queues.Task(); Queues.add(t); //执行该方法,激活所有对应队列,那两个线程就会开始执行啦 } } 上面的就是很简单的例子了
来源于网络,供您参考
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
涵盖 RocketMQ、Kafka、RabbitMQ、MQTT、轻量消息队列(原MNS) 的消息队列产品体系,全系产品 Serverless 化。RocketMQ 一站式学习:https://rocketmq.io/