两个线程同时读取相同的索引
ArrayList如果 列表是由分支
ThreadAand
的线程构造的,
ThreadB并且列表在线程被分支之前已完全构建并加载,则可以从公共线程读取多个线程。
这样做的原因是,使用线程和派生该线程的线程的内存存在事前保证。如果,例如,
ThreadC构建
ArrayList但 之后
ThreadA和
ThreadB被分叉,那么就无法保证A和B将充分看到
ArrayList-如果在所有。
如果不是这种情况,那么您将需要同步列表。见下文。
ThreadA更改ThreadB试图同时访问的元素,假设您不在乎ThreadB是获取旧元素还是获取新元素。
一旦讨论了在并发设置中对列表的修改,则必须在该列表上进行同步,否则无法保证将发布修改,并且有可能部分发布列表,这可能导致数据异常。正如@Marko所说,其内部状态可能不一致。
您可以使用
CopyOnWriteArrayList专为少量更新和多次读取而设计的,用于
Collections.synchronizedList(...)使列表受到保护,可以始终在一个
synchronized块中访问列表(对于所有写入
和 读取),也可以切换到使用并发集合,例如作为
ConcurrentSkipList或某物。
ThreadA更改ThreadB试图同时访问的元素
这有点模棱两可。如果你是在谈论,例如,在列表中存储的对象,然后改变碰巧被存储在列表中的对象,那么你不会有一个同步的问题 列表 ,但你将与一个同步问题
对象
。如果列表的数据没有变化,那就可以了。但是,如果您需要保护该对象,则需要该对象中的
AtomicReference<YourObject>,
volatile字段列表或进行其他同步,以确保更改在线程之间发布。



