在Java中,可以使用SynchronousQueue來實現(xiàn)線程之間的同步通信。SynchronousQueue是一個不存儲元素的阻塞隊列,它的主要特點是生產(chǎn)者線程必須等待消費者線程消費完元素后才能繼續(xù)生產(chǎn)新的元素。
以下是使用SynchronousQueue的示例代碼:
import java.util.concurrent.SynchronousQueue;
public class SynchronousQueueExample {
public static void main(String[] args) {
SynchronousQueue<Integer> queue = new SynchronousQueue<>();
// 創(chuàng)建生產(chǎn)者線程
Thread producer = new Thread(() -> {
try {
int value = 1;
while (true) {
// 將元素放入隊列
queue.put(value);
System.out.println("生產(chǎn)者生產(chǎn)了:" + value);
value++;
// 模擬生產(chǎn)者生產(chǎn)時間
Thread.sleep(1000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
// 創(chuàng)建消費者線程
Thread consumer = new Thread(() -> {
try {
while (true) {
// 從隊列中取出元素
int value = queue.take();
System.out.println("消費者消費了:" + value);
// 模擬消費者消費時間
Thread.sleep(2000);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
});
// 啟動生產(chǎn)者和消費者線程
producer.start();
consumer.start();
}
}
在上述代碼中,首先創(chuàng)建了一個SynchronousQueue實例。然后創(chuàng)建了一個生產(chǎn)者線程,不斷地生產(chǎn)元素并放入隊列中。創(chuàng)建了一個消費者線程,不斷地從隊列中取出元素進行消費。生產(chǎn)者和消費者線程同時運行,但生產(chǎn)者必須等待消費者消費完元素后才能繼續(xù)生產(chǎn)新的元素,這樣就實現(xiàn)了線程之間的同步。