boundedbuffer.scala
来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 47 行
SCALA
47 行
package examplesobject boundedbuffer { import concurrent.ops._ class BoundedBuffer[a](N: Int) { var in, out, n = 0 val elems = new Array[a](N) def await(cond: => Boolean) = while (!cond) { wait() } def put(x: a) = synchronized { await (n < N) elems(in) = x; in = (in + 1) % N; n += 1 if (n == 1) notifyAll() } def get: a = synchronized { await (n != 0) val x = elems(out); out = (out + 1) % N ; n -= 1 if (n == N - 1) notifyAll() x } } def kill(delay: Int) = new java.util.Timer().schedule( new java.util.TimerTask { override def run() = { println("[killed]") System.exit(0) } }, delay) // in milliseconds def main(args: Array[String]) { val buf = new BoundedBuffer[String](10) var cnt = 0 def produceString = { cnt += 1; cnt.toString() } def consumeString(ss: String) = println(ss) spawn { while (true) { val ssss = produceString; buf.put(ssss) } } spawn { while (true) { val s = buf.get; consumeString(s) } } kill(1000) }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?