一道面試題

一道面試題

最近在校招戚绕,我們的題庫里面有這樣一道題:3個線程,分別打印a枝冀、b舞丛、c,保證打印順序:abc果漾。

我覺得這道題挺有意思的球切,所以在這道題上面再做了一點擴展。

1.1 啟動3個線程分別打印abc

public Thread createThread(final String name, final CountDownLatch countDownLatch) {
return new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(new Random().nextInt(1000)%1000);
}
catch (Exception e) {
}
countDownLatch.countDown();
System.out.println(name);
}
});
}
/**
* CountDownLatch
*/
public void test1(){
final CountDownLatch countDownLatch= new CountDownLatch(3);
createThread("A", countDownLatch).start();
createThread("B", countDownLatch).start();
createThread("C", countDownLatch).start();
try {
countDownLatch.await();
}
catch (Exception e) {
}
}

1.2 使用Semaphore 完成保證打印順序:abc

public Thread createThread(final String name, final CountDownLatch countDownLatch, final Semaphore acquire, final Semaphore release) {
return new Thread(new Runnable() {
@Override
public void run() {
try {
acquire.acquire();
Thread.sleep(new Random().nextInt(1000)%1000);
countDownLatch.countDown();
System.out.println(name);
release.release();
}
catch (Exception e) {
}
}
});
}
/**
* Semaphore
*/
public void test2(){
final CountDownLatch countDownLatch= new CountDownLatch(3);
final Semaphore A = new Semaphore(1);
final Semaphore B = new Semaphore(0);
final Semaphore C = new Semaphore(0);
createThread("A", countDownLatch, A, B).start();
createThread("B", countDownLatch, B, C).start();
createThread("C", countDownLatch, C, A).start();
try {
countDownLatch.await();
}
catch (Exception e) {
}
}

1.3 使用AtomicInteger 完成保證打印順序:abc

public Thread createThread(final char name, final CountDownLatch countDownLatch,final AtomicInteger single) {
return new Thread(new Runnable() {
@Override
public void run() {
try {
while (single.get()%3!=name%3){
}
Thread.sleep(2000);
System.out.println(name);
countDownLatch.countDown();
single.incrementAndGet();
}
catch (Exception e) {
}
}
});
}
/**
* while
*/
public void test4(){
final AtomicInteger single= new AtomicInteger(2);
final CountDownLatch countDownLatch= new CountDownLatch(3);
createThread('A', countDownLatch, single).start();
createThread('B', countDownLatch, single).start();
createThread('C', countDownLatch, single).start();
try {
countDownLatch.await();
}
catch (Exception e) {
}
}

1.4 使用condition 完成保證打印順序:abc

public Thread createThread(final char name, final CountDownLatch countDownLatch,final AtomicInteger single, final Condition condition, final ReentrantLock lock) {
return new Thread(new Runnable() {
@Override
public void run() {
try {
lock.lock();
while (single.get()%3!=name%3){
condition.await();
}
Thread.sleep(new Random().nextInt(1000)%1000);
System.out.println(name);
countDownLatch.countDown();
single.incrementAndGet();
condition.signalAll();
}
catch (Exception e) {
}
finally {
lock.unlock();
}
}
});
}
/**
* ReentrantLock
* Condition
*/
public void test3(){
final ReentrantLock lock= new ReentrantLock();
final Condition condition= lock.newCondition();
final AtomicInteger single= new AtomicInteger(0);
final CountDownLatch countDownLatch= new CountDownLatch(3);
createThread('A', countDownLatch, single, condition, lock).start();
createThread('B', countDownLatch, single, condition, lock).start();
createThread('C', countDownLatch, single, condition, lock).start();
try {
countDownLatch.await();
}
catch (Exception e) {
}
}

1.5 使用synchronized 完成保證打印順序:abc

public Thread createThread2(final char name, final CountDownLatch countDownLatch,final AtomicInteger single) {
return new Thread(new Runnable() {
@Override
public void run() {
try {
while (single.get()%3!=name%3){
synchronized (single){
single.wait();
}
}
Thread.sleep(new Random().nextInt(1000)%1000);
System.out.println(name);
countDownLatch.countDown();
single.incrementAndGet();
synchronized (single){
single.notifyAll();
}
}
catch (Exception e) {
}
finally {
}
}
});
}
/**
* synchronized
*/
public void test5(){
final AtomicInteger single= new AtomicInteger(2);
final CountDownLatch countDownLatch= new CountDownLatch(3);
createThread2('A', countDownLatch, single).start();
createThread2('B', countDownLatch, single).start();
createThread2('C', countDownLatch, single).start();
try {
countDownLatch.await();
}
catch (Exception e) {
}
}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绒障,一起剝皮案震驚了整個濱河市吨凑,隨后出現(xiàn)的幾起案子梯醒,更是在濱河造成了極大的恐慌,老刑警劉巖料皇,帶你破解...
    沈念sama閱讀 217,826評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件介返,死亡現(xiàn)場離奇詭異,居然都是意外死亡蒋伦,警方通過查閱死者的電腦和手機弓摘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來痕届,“玉大人韧献,你說我怎么就攤上這事⊙薪校” “怎么了锤窑?”我有些...
    開封第一講書人閱讀 164,234評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長嚷炉。 經(jīng)常有香客問我渊啰,道長,這世上最難降的妖魔是什么申屹? 我笑而不...
    開封第一講書人閱讀 58,562評論 1 293
  • 正文 為了忘掉前任绘证,我火速辦了婚禮,結果婚禮上哗讥,老公的妹妹穿的比我還像新娘嚷那。我一直安慰自己,他們只是感情好杆煞,可當我...
    茶點故事閱讀 67,611評論 6 392
  • 文/花漫 我一把揭開白布魏宽。 她就那樣靜靜地躺著,像睡著了一般决乎。 火紅的嫁衣襯著肌膚如雪队询。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,482評論 1 302
  • 那天瑞驱,我揣著相機與錄音娘摔,去河邊找鬼。 笑死唤反,一個胖子當著我的面吹牛凳寺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播彤侍,決...
    沈念sama閱讀 40,271評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼肠缨,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了盏阶?” 一聲冷哼從身側響起晒奕,我...
    開封第一講書人閱讀 39,166評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后脑慧,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體魄眉,經(jīng)...
    沈念sama閱讀 45,608評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,814評論 3 336
  • 正文 我和宋清朗相戀三年闷袒,在試婚紗的時候發(fā)現(xiàn)自己被綠了坑律。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,926評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡囊骤,死狀恐怖晃择,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情也物,我是刑警寧澤宫屠,帶...
    沈念sama閱讀 35,644評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站滑蚯,受9級特大地震影響浪蹂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜告材,卻給世界環(huán)境...
    茶點故事閱讀 41,249評論 3 329
  • 文/蒙蒙 一乌逐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧创葡,春花似錦、人聲如沸绢慢。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胰舆。三九已至骚露,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間缚窿,已是汗流浹背棘幸。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留倦零,地道東北人误续。 一個月前我還...
    沈念sama閱讀 48,063評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像扫茅,于是被迫代替她去往敵國和親蹋嵌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,871評論 2 354

推薦閱讀更多精彩內(nèi)容