espère être implémentée est de réaliser une telle fonction pourList
提供一个原子操作:若没有则添加。因为ArrayList
本身不是线程安全的,所以通过集合Collections.synchronizedList
将其转换为一个线程安全的类,然后通过一个辅助的方法来为List
.
class BadListHelper { public List list = Collections.synchronizedList(new ArrayList()); public synchronized boolean putIfAbsent(E x) { boolean absent = !list.contains(x); if (absent) list.add(x); return absent; } }
Ce code est-il dangereux ? Si oui, pouvez-vous le prouver ? Merci
Utilisez simplement
ConcurrentSkipListSet
et c'est très bienUne liste non répétitive n'est qu'un ensemble, n'est-ce pas ? , nécessite des atomes, n'est-ce pas un ensemble thread-safe ?