Scala的Akka編程中代碼保持線程安全的重要性

今天我提交我的遠程分支合併到git orgin/master的請求,亮哥給了我一些指導。


 started a discussion on the diff

web/datacloud-web/app/com/mininglamp/datacloud/web/handler/db/DBUserHandler.scala

37

36}.flatMap {
3837_.headOption match {
3938case Some(x) => Future.failed(UserAlreadyExists(x.username))
40
-          case None => Future.successful(u.username)

39+          case None => {

40+            db.run {

41+              DataCloudUsers.forceInsert(u)

42+            }
 1
  • Master亮哥 @Liangliang  21 minutes ago

    這裏如果是多線程的話,db還沒成功,可能程序就返回Future.successful了。所以db.run{}.onComplete裏返回successful


其實這樣寫在多線程環境中不能同步,用onComplete()方法做一個完美連接,就能保持同步。我現在在db.run後面沒有用這個方法而直接返回了Future.successful(u.username),這樣確實不合理,要保持連貫性,或者用flatMap也可以。


順便了解了一下


new scala.collection.mutable.LinkedHashMap[String, Any]() with scala.collection.mutable.SynchronizedMap[String, Any]

在scala中實現SynchronizedMap就可以實現同步,或者concurrent.Map trait也可以.

cocurrentHashMap引入了分段鎖的概念,不是鎖整個HashMap,效率極大提高.


syncronized關鍵字也是一種方式:someMap.synchronized { someMap += ("someKey", "anyValue") }


http://www.scala-lang.org/docu/files/collections-api/collections_11.html


http://stackoverflow.com/questions/7952553/is-scalas-pattern-matching-regex-thread-safe


正則表達式由於繼承類的關係,有些線程安全,有些則不是.scala.util.matching.Regex依賴於java.util.regex.Pattern,是線程安全的,但scala.util.matching.Regex.Match和scala.util.matching.Regex.MatchIterator不是線程安全的,scala.util.matching.Regex.MatchData是上述兩個類的一部分,所以也找不到線程安全的實例.

因此在多線程環境中正則表達式匹配最好用scala.util.matching.Regex實現.


查了半天還是沒查到match關鍵字和map是否線程安全,網上說的map是Map集合,不是map方法,可能需要查看一下底層實現.


後來經樑兄指導,每個消息都是獨立的,內部肯定都會線程安全.


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章