Java并发编程最常用和易用的技术莫过于synchronized关键字,而Scala的并发编程之旅也可以从synchronized开始。而synchronized的背后其实是monitor技术。
什么是Monitor
Monitor是解决并发编程问题的一种常用技术,可以有效解决互斥和同步两大常见问题,通常翻译为‘监视器’或‘管程’。个人认为‘管程‘更能表达monitor的含义,指的是管理共享变量以及对共享变量的操作过程,让他们支持并发。
Scala的synchronized
Synchronized是Java对monitor的实现,可以对代码块或方法使用,使得每次只能有一个线程访问,实现了线程互斥。当一个线程获取了锁,其他线程将在队列上等待,实现了线程同步。
Scala延用了这一关键字,但是语法有所不同。
//用于代码块
obj.synchronized {
...
}
//用于方法
def func(): Unit = this.synchronized {
...
}
跟Java一样,这里的this是可以省略的,因为默认加锁的对象就是this,但是不建议省略。
Scala实例
import java.util.concurrent.TimeUnit
object SynchronizedDemo {
private var inc: Int = 0
def addOne(): Unit = this.synchronized {
TimeUnit.SECONDS.sleep(1)
inc = 1
}
def main(args: Array[String]): Unit = {
for (i <- 1 to 10) {