Scala的Akka编程中代码保持线程安全的重要性-创新互联
今天我提交我的远程分支合并到git orgin/master的请求,亮哥给了我一些指导。
创新互联建站于2013年创立,是专业互联网技术服务公司,拥有项目成都网站建设、网站制作网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元河北做网站,已为上家服务,为河北各地企业和个人服务,联系电话:13518219792亮哥 started a discussion on the diff
web/datacloud-web/app/com/mininglamp/datacloud/web/handler/db/DBUserHandler.scala
37 | 36 | }.flatMap { |
38 | 37 | _.headOption match { |
39 | 38 | case 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 |
|
其实这样写在多线程环境中不能同步,用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方法,可能需要查看一下底层实现.
后来经梁兄指导,每个消息都是独立的,内部肯定都会线程安全.
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享文章:Scala的Akka编程中代码保持线程安全的重要性-创新互联
URL地址:http://scyanting.com/article/cdepcs.html