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

我正在 scala一个计算库.类似的功能我分组到本地scala单例对象包含一些程序和一些静态分配的内存为O(1)时间数据.

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

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

是否可能在scala?

解决方法

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

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

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...