Synchronized or ReentrantLock?
kotlin虽然没有Synchronized
关键字,但是提供了同名的inline函数,可以应付一般的多线程同步场景。
private val lock = Object()
...
synchronized(lock) {
...
}
但是kotlin的synchronized只能兼容jvm平台,所以在跨平台时无法使用,目前已经被Deprecated
在这,Object
的notify
、wait
等方法Kotlin中也无法使用; Synchronized加锁后没有timeout也是其相对于ReentrantLock的缺陷,鉴于以上原因,我推荐大家在Kotlin中更多的使用ReentrantLock
Kotlin + ReentrantLock
Use Custom Class
我们可以定义一个Lock类
class Lock {
private val lock = ReentrantLock()
fun withLock(block: () -> Unit) {
try {
lock.lock()
block()
} finally {
lock.unlock()
}
}
}
然后,可以使用 lock.withLock { }
替代 synchronized(lock) { }
当然,你需要实现创建一个Lock
实例
Use Extension Function
我们也可以通过扩展方法,避免额外类型的定义
(摘自kotlin.concurrent.LocksKt
):
@kotlin.internal.InlineOnly
public inline fun <T> Lock.withLock(action: () -> T): T {
lock()
try {
return action()
} finally {
unlock()
}
}