|
Scala example source code file (boundedbuffer.scala)
The Scala boundedbuffer.scala source code
package examples
object boundedbuffer {
import concurrent.ops._
class BoundedBuffer[A](N: Int)(implicit m: ClassManifest[A]) {
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)
}
}
Other Scala examples (source code examples)Here is a short list of links related to this Scala boundedbuffer.scala source code file: |
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.