创建具有唯一id的多个线程(线程不重叠)



更新

我正在解决一个生产者/消费者问题,我想创建几个生产者和消费者(几个线程(,我有一个问题,我如何正确创建几个线程,使一个任务不由两个线程执行(每个线程执行不同的任务(。

代码:我试着在一个循环中这样做:

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
    public class ProducerConsumerExample {
    
        public static void main(String[] args) {
    
            BlockingQueue<String> blockingQueue = new ArrayBlockingQueue<>(10);
    
            for (int i = 0; i < 10 ; i++) {
                Producer producer = new Producer(blockingQueue);
                Consumer consumer = new Consumer(blockingQueue);
    
                Thread producerThread = new Thread(producer);
                Thread consumerThread = new Thread(consumer);
    
                producerThread.start();
                consumerThread.start();
            }
        }
    }

输出:但它不起作用,因为线程彼此重叠

Producer produced : 1619703940537
Producer produced : 1619703940537
Producer produced : 1619703940537
Producer produced : 1619703940537
consumed gets: 1619703940537
consumed gets: 1619703940537
consumed gets: 1619703940537
consumed gets: 1619703940537
Producer produced : 1619703940537
consumed gets: 1619703940537

您看到多个线程使用相同的System.currentTimeMillis()值,这使得无法判断发生了什么。将传递到队列中的令牌更改为唯一的PER-Productor,并包含线程名称:

public void run() {
    int counter=0;
    while (true) {
        try {
            String token = Thread.currentThread().toString() + "#"+(counter++);
            this.blockingQueue.put(token );
            System.out.println("Producer produced nr: " + token );
        } catch (InterruptedException e ) {
            System.out.println("Producer was interrupted");
        }
        sleep();
    }
}

更改Consumer.run()以打印线程名称,您将更清楚地看到哪个Consumer实例正在消耗每个操作,以及哪个Producer:

System.out.println("consumer "+Thread.currentThread()+" gets: " + element);

这将有望证明,这是几个生产者+消费者处理程序,以及生产者-消费者从同一个BlockingQueue发送和接收项目的不同排列。

您要查找的是线程池。Java中包含了各种各样的实现,这些实现应该是开箱即用的。以下是我对javatpoint:的定义

Java线程池表示一组等待作业并多次重用的工作线程。在线程池的情况下,会创建一组固定大小的线程。线程池中的一个线程由服务提供商拉出并分配一个作业。

您可以查看以下页面了解更多信息:

https://www.baeldung.com/thread-pool-java-and-guavahttps://docs.oracle.com/javase/tutorial/essential/concurrency/pools.html

最新更新