|
1
11
此用途是线程安全的:
此使用不是线程安全的,可能会导致越界异常:
当然,用户仍然可以将GetValues()放在循环中,这也会很糟糕,但至少它显然很糟糕。
|
|
|
2
9
没有任何额外的保护,就没有 保证 一条阅读线索 曾经 查看新值。在实践中,只要阅读线索是做任何有意义的事情,它 将
如果你成功了
|
|
|
3
6
read和replacement保证是原子的,但是不能保证在write之后的read必然会读取新的值。
现有代码不会有什么不好的情况发生(例如,读取错误),但是不能保证您的读者会这样做 曾经 查看新值。例如,旧引用有可能(尽管可能不太可能)永远缓存在寄存器中。 |
|
|
4
2
这不是线程安全的。是的,你需要用锁。 |
|
|
5
2
ReaderWriterLockSlim -效率比 ReaderWriteLock .
|
|
|
6
1
Java theory and practice: Fixing the Java Memory Model, Part 2 ):
后者是一个有趣的例子:你曾经能够
|