我正在
scala写一个计算库.类似的功能我分组到本地scala单例对象包含一些程序和一些静态分配的内存为O(1)时间数据.
这种方法适合单线程使用.但是同时从不同的线程调用库函数可能会覆盖时间数据,并给调用者提供不正确的答案.
我可以通过在函数本地空间中移动所有静态分配的内存来复制此库并编写线程安全版本.但是我更喜欢通过定义线程局部变量来避免它.
是否可能在scala?
解决方法
只需使用
Java的java.lang.ThreadLocal类来存储变量.
val tl = new ThreadLocal[String] tl.set("fish") tl.get // "fish"
请注意,这样做会导致非零性能损失(我记得在我手中约6 ns).如果你做的是真正轻量级的东西(例如递增索引),你可能会注意到速度的差异.
原文地址:https://www.jb51.cc/java/122215.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。