加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

多线程 – 同步计数器在clojure

发布时间:2020-12-14 17:47:31 所属栏目:Java 来源:网络整理
导读:如果我想保留一个全局计数器(例如,计算跨多个线程的传入请求数),那么在 java中最好的方式是使用volatile int.假设使用clojure是否有更好的(更好的吞吐量)方式? 解决方法 我会在Clojure中用 atom做这个: (def counter (atom 0N));; increment the counter(s
如果我想保留一个全局计数器(例如,计算跨多个线程的传入请求数),那么在 java中最好的方式是使用volatile int.假设使用clojure是否有更好的(更好的吞吐量)方式?

解决方法

我会在Clojure中用 atom做这个:
(def counter (atom 0N))

;; increment the counter
(swap! counter inc)

;; read the counter
@counter
=> 1

这是完全线程安全的,令人惊讶的高性能.此外,由于它使用Clojure的精确数字处理,所以它不容易受到整数溢出的影响,因为volatile int可以是…..

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读