What object do I synchronize on in Scala?

后端 未结 3 2272
情歌与酒
情歌与酒 2021-02-19 02:58

In C# it\'s pretty straightforward:

class Class1{
  private static readonly object locker = new object();
  void Method1(){
    lock(locker) { .... }
  }
}


        
相关标签:
3条回答
  • 2021-02-19 03:36

    If the premise is that you want to avoid locking on this because another thread with third party code can lock on the same object, then Scala offers one more level of visibility private[this].

    class C {
      private[this] val lock = new Object()
      def method1(): Unit = lock.synchronized {
        println("method1")
      }
    }
    

    Here actually no other object other than a particular instance of C can access lock. Even other instances from the same class cannot access lock.

    0 讨论(0)
  • 2021-02-19 03:38
    1. Having a lock on object in Scala is the same as having the lock on static field/class in Java, which is basically one of 'hardest' locks. It will block operations not on instance of class, but on class itself in scope of class loader. You should think carefully when introducing locks like this. It doesn't protect you from a deadlock due to incorrect ordering of acquired locks, but instead leads to blocking threads if ones are working with different instances of a class, and may not interfere at all.

    2. having a lock on 'this' or some class (not object) field (mutex) is more relaxed way of synchronization, you should use it for managing access not to class - but to particular instance of this class.

    3. look at actors in akka, they rock and eliminate many of problems with synchronization.

    side-note: making synchronization on 'this' doesn't imply deadlocks.

    0 讨论(0)
  • 2021-02-19 03:42

    In Scala it's even more straightforward to get the same behavior (I'm assuming you want to lock on the contained object for some reason e.g. more fine-grained control than locking the whole instance of that class):

    class Class1 {
      private object Locker
      def method1 { Locker.synchronized { ... } }
    }
    

    But you should rarely control things this way. In particular, it won't prevent deadlocks in either C# or Scala without a lot of attention to what goes into ....

    You should at least use the concurrency tools in java.util.concurrent, and you may want to look into futures or actors.

    0 讨论(0)
提交回复
热议问题