我知道这ArrayList
不是线程安全的,但是我不确定其确切含义。
在ThreadA
和ThreadB
都使用的情况下ArrayList
,以下哪种情况会引起问题并需要同步?
ThreadA``ThreadB
假设您不在乎ThreadB
获取旧元素还是新元素,则替换尝试同时访问的元素。两个线程同时读取相同的索引
ArrayList
如果 列表是由分支ThreadA
and
的线程构造的,ThreadB
并且列表在线程被分支之前已完全构建并加载,则可以从公共线程读取多个线程。
这样做的原因是,使用线程和派生该线程的线程的内存存在事前保证。如果,例如,ThreadC
构建ArrayList
但 之后
ThreadA
和ThreadB
被分叉,那么就无法保证A和B将充分看到ArrayList
-如果在所有。
如果不是这种情况,那么您将需要同步列表。见下文。
ThreadA更改ThreadB试图同时访问的元素,假设您不在乎ThreadB是获取旧元素还是获取新元素。
一旦讨论了在并发设置中对列表的修改,则必须在该列表上进行同步,否则无法保证将发布修改,并且有可能部分发布列表,这可能导致数据异常。正如@Marko所说,其内部状态可能不一致。
您可以使用CopyOnWriteArrayList
专为少量更新和多次读取而设计的,用于Collections.synchronizedList(...)
使列表受到保护,可以始终在一个synchronized
块中访问列表(对于所有写入
和 读取),也可以切换到使用并发集合,例如作为ConcurrentSkipList
或某物。
ThreadA更改ThreadB试图同时访问的元素
这有点模棱两可。如果你是在谈论,例如,在列表中存储的对象,然后改变碰巧被存储在列表中的对象,那么你不会有一个同步的问题 列表 ,但你将与一个同步问题
对象
。如果列表的数据没有变化,那就可以了。但是,如果您需要保护该对象,则需要该对象中的AtomicReference<YourObject>
,volatile
字段列表或进行其他同步,以确保更改在线程之间发布。
问题内容: 我正在用Java创建一个多线程聊天。当用户u1向用户u2发送消息但未连接用户u2时,用户u1将消息发送至服务器,而用户u2一旦连接至服务器,便会收到该消息。未发送的消息将添加到ArrayList中。连接用户后,他会检查自己是否是未决邮件的收件人。如果是,则将邮件发送给他,然后将其从待处理邮件列表中删除。这是我的方法: 这就是我得到的: 我如何解决它?是因为我正在使用迭代器吗? 问题答案
编辑 这些更改导致并发mod每次触发而不是断断续续地触发,我想这意味着删除代码更好,但现在错误在触发 线程“awt-eventqueue-0”java.util.concurrentModificatio中的异常nException at java.util.arrayList$itr.checkforcoModification(arrayList.java:901)at java.util.a
问题内容: 在具有并发访问的程序中使用映射时,是否需要在函数中使用互斥体来 读取 值? 问题答案: 读者众多,没有作家可以: https://groups.google.com/d/msg/golang- nuts/HpLWnGTp-n8/hyUYmnWJqiQJ 一个作家,没有读者是可以的。(否则,地图不会太好。) 否则,如果至少有一个作家,而作家或读者至少还有一个,那么 所有 读者 和 作家都
我是Java新手,目前正在为一个项目使用BlueJ。我在访问此类对象的ArrayList的ArrayList中的对象时遇到问题。假设我有一个学生对象: 然后是获取地址、月份、年份和等级的方法。然后我有一个类,它是学生对象的数组列表: 这个类包括添加学生对象、列出类中的所有学生(ListallStudentsInClass)的方法,该类返回学生的ArrayList、查找类中成绩最高的学生(getHi
本文向大家介绍Go 并发访问地图,包括了Go 并发访问地图的使用技巧和注意事项,需要的朋友参考一下 示例 进行中的映射并发并不安全。如果要同时访问它们,则必须加锁以对其进行读写。通常,最好的选择是使用,sync.RWMutex因为您可以拥有读写锁。但是,sync.Mutex也可以使用a。 包装函数的权衡是在基础图的公共访问与正确使用适当的锁之间。
当我使用temp=iterator.next()时,sort方法会导致并发修改错误。你能帮我解决并发修改错误吗。我给出了整个类的代码,但我只是尝试完成sort方法。事先谢谢你的帮助。 我必须对ArrayList中的所有数组进行排序。