溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2020-07-02 03:57:47 來(lái)源:網(wǎng)絡(luò) 閱讀:2628 作者:金明略 欄目:開(kāi)發(fā)技術(shù)

今天我提交我的遠(yuǎn)程分支合并到git orgin/master的請(qǐng)求,亮哥給了我一些指導(dǎo)。


亮哥 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
  • Scala的Akka編程中代碼保持線程安全的重要性

    Master亮哥 @Liangliang  21 minutes ago

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


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


順便了解了一下


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

在scala中實(shí)現(xiàn)SynchronizedMap就可以實(shí)現(xiàn)同步,或者concurrent.Map trait也可以.

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


syncronized關(guān)鍵字也是一種方式: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


正則表達(dá)式由于繼承類的關(guān)系,有些線程安全,有些則不是.scala.util.matching.Regex依賴于java.util.regex.Pattern,是線程安全的,但scala.util.matching.Regex.Match和scala.util.matching.Regex.MatchIterator不是線程安全的,scala.util.matching.Regex.MatchData是上述兩個(gè)類的一部分,所以也找不到線程安全的實(shí)例.

因此在多線程環(huán)境中正則表達(dá)式匹配最好用scala.util.matching.Regex實(shí)現(xiàn).


查了半天還是沒(méi)查到match關(guān)鍵字和map是否線程安全,網(wǎng)上說(shuō)的map是Map集合,不是map方法,可能需要查看一下底層實(shí)現(xiàn).


后來(lái)經(jīng)梁兄指導(dǎo),每個(gè)消息都是獨(dú)立的,內(nèi)部肯定都會(huì)線程安全.


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI