多线程 – 在scala上创建线程本地对象
发布时间:2020-12-14 05:31:46 所属栏目:Java 来源:网络整理
导读:我正在 scala写一个计算库.类似的功能我分组到本地scala单例对象包含一些程序和一些静态分配的内存为O(1)时间数据. 这种方法适合单线程使用.但是同时从不同的线程调用库函数可能会覆盖时间数据,并给调用者提供不正确的答案. 我可以通过在函数本地空间中移动
我正在
scala写一个计算库.类似的功能我分组到本地scala单例对象包含一些程序和一些静态分配的内存为O(1)时间数据.
这种方法适合单线程使用.但是同时从不同的线程调用库函数可能会覆盖时间数据,并给调用者提供不正确的答案. 我可以通过在函数本地空间中移动所有静态分配的内存来复制此库并编写线程安全版本.但是我更喜欢通过定义线程局部变量来避免它. 是否可能在scala? 解决方法
只需使用
Java的java.lang.ThreadLocal类来存储变量.
val tl = new ThreadLocal[String] tl.set("fish") tl.get // "fish" 请注意,这样做会导致非零性能损失(我记得在我手中约6 ns).如果你做的是真正轻量级的东西(例如递增索引),你可能会注意到速度的差异. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |