交替列印FooBar

2021-10-22 10:20:39 字數 946 閱讀 8854

我們提供乙個類:

class

foobar

}public

void

bar()}

}

兩個不同的執行緒將會共用乙個 foobar 例項。其中乙個執行緒將會呼叫 foo() 方法,另乙個執行緒將會呼叫 bar() 方法。

請設計修改程式,以確保 「foobar」 被輸出 n 次。

示例 1:

輸入: n = 1

輸出: 「foobar」

解釋: 這裡有兩個執行緒被非同步啟動。其中乙個呼叫 foo() 方法, 另乙個呼叫 bar() 方法,「foobar」 將被輸出一次。

示例 2:

輸入: n = 2

輸出: 「foobarfoobar」

解釋: 「foobar」 將被輸出兩次。

本題用訊號量去解決也很簡單,不過這裡需要用到2個訊號量,訊號量a和訊號量b。a用來釋放列印bar方法,b用來釋放列印foo方法,同時注意在初始化訊號量時讓訊號量b的值為1,讓程式能正常執行。

class

foobar

public

void

foo(runnable printfoo)

throws interruptedexception

}public

void

bar(runnable printbar)

throws interruptedexception

}}

提交**後,執行時間與使用記憶體如下:

交替列印FooBar

我們提供乙個類 class foobar public void bar 兩個不同的執行緒將會共用乙個 foobar 例項。其中乙個執行緒將會呼叫 foo 方法,另乙個執行緒將會呼叫 bar 方法。請設計修改程式,以確保 foobar 被輸出 n 次。示例 1 輸入 n 1 輸出 foobar 解釋...

1115 交替列印FooBar

我們提供乙個類 class foobar public void bar 兩個不同的執行緒將會共用乙個 foobar 例項。其中乙個執行緒將會呼叫 foo 方法,另乙個執行緒將會呼叫 bar 方法。請設計修改程式,以確保 foobar 被輸出 n 次。示例 1 輸入 n 1 輸出 foobar 解釋...

1115 交替列印FooBar

題目描述 我們提供乙個類 class foobar public void bar 兩個不同的執行緒將會共用乙個 foobar 例項。其中乙個執行緒將會呼叫 foo 方法,另乙個執行緒將會呼叫 bar 方法。請設計修改程式,以確保 foobar 被輸出 n 次。示例 1 輸入 n 1 輸出 foob...