多线程 – 在scala上创建线程本地对象

前端之家收集整理的这篇文章主要介绍了多线程 – 在scala上创建线程本地对象前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在 scala写一个计算库.类似的功能我分组到本地scala单例对象包含一些程序和一些静态分配的内存为O(1)时间数据.

这种方法适合单线程使用.但是同时从不同的线程调用函数可能会覆盖时间数据,并给调用者提供不正确的答案.

我可以通过在函数本地空间中移动所有静态分配的内存来复制此库并编写线程安全版本.但是我更喜欢通过定义线程局部变量来避免它.

是否可能在scala?

解决方法

只需使用 Java的java.lang.ThreadLocal类来存储变量.
val tl = new ThreadLocal[String]
tl.set("fish")
tl.get   // "fish"

请注意,这样做会导致非零性能损失(我记得在我手中约6 ns).如果你做的是真正轻量级的东西(例如递增索引),你可能会注意到速度的差异.

猜你在找的Java相关文章