这种方法适合单线程使用.但是同时从不同的线程调用库函数可能会覆盖时间数据,并给调用者提供不正确的答案.
我可以通过在函数本地空间中移动所有静态分配的内存来复制此库并编写线程安全版本.但是我更喜欢通过定义线程局部变量来避免它.
是否可能在scala?
val tl = new ThreadLocal[String] tl.set("fish") tl.get // "fish"
请注意,这样做会导致非零性能损失(我记得在我手中约6 ns).如果你做的是真正轻量级的东西(例如递增索引),你可能会注意到速度的差异.