Thread.join()
方法用于等待線程執(zhí)行完成。在使用同步工具類時(shí),我們通常關(guān)心的是如何確保多個(gè)線程在訪問(wèn)共享資源時(shí)的正確性和安全性。Thread.join()
本身并不直接提供同步功能,但它可以與同步工具類結(jié)合使用來(lái)實(shí)現(xiàn)線程間的協(xié)作。
例如,假設(shè)我們有兩個(gè)線程ThreadA
和ThreadB
,我們希望ThreadB
在ThreadA
執(zhí)行完成之后再繼續(xù)執(zhí)行。我們可以使用Thread.join()
方法來(lái)實(shí)現(xiàn)這一點(diǎn)。同時(shí),為了確保在ThreadA
和ThreadB
之間正確地同步訪問(wèn)共享資源,我們可以使用synchronized
關(guān)鍵字或其他同步工具類(如ReentrantLock
、Semaphore
等)。
下面是一個(gè)簡(jiǎn)單的示例,展示了如何使用Thread.join()
和synchronized
關(guān)鍵字來(lái)同步線程:
public class SynchronizedExample {
private static final Object lock = new Object();
public static void main(String[] args) throws InterruptedException {
Thread threadA = new Thread(() -> {
synchronized (lock) {
System.out.println("Thread A acquired lock");
try {
// 模擬耗時(shí)操作
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("Thread A released lock");
}
});
Thread threadB = new Thread(() -> {
try {
// 等待線程A執(zhí)行完成
threadA.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("Thread B executed after Thread A");
});
threadA.start();
threadB.start();
}
}
在這個(gè)示例中,我們使用了一個(gè)名為lock
的對(duì)象作為同步鎖。ThreadA
和ThreadB
都使用synchronized
關(guān)鍵字來(lái)獲取和釋放這個(gè)鎖。ThreadB
使用threadA.join()
方法來(lái)等待ThreadA
執(zhí)行完成。這樣,我們可以確保在ThreadA
和ThreadB
之間正確地同步訪問(wèn)共享資源。