ser*_*rah 0 java concurrency multithreading
我需要一个线程安全的并发列表,同时最适合迭代,并且应该返回确切的大小.我想存储商品的竞价出价.所以我希望能够
我计划将它放在
ConcurrentHashMap<Item, LinkedList<ItemBid>>- LinkedList不是线程安全的但返回确切的大小
ConcurrentHashMap<Item, ConcurrentLinkedQueue<ItemBid>>- concurrentlinked队列是线程安全的但不保证返回确切的大小
有没有其他更好的集合将解决上述4点并且是线程安全的.
可以说,在线程安全的集合或映射中,您无法保证大小的"一致性",这意味着读取和写入操作之间的"先发生"关系不会有益于您所需的用例,其中对大小进行读取操作应该返回一个反映上次写操作的确切状态的值(注意:根据注释改进 - 见下文).
如果性能不是问题,你可以做的是使用以下习语 - 或者:
Collections.synchronizedMap(new HashMap<YourKeyType, YourValueType>());Collections.synchronizedList(new ArrayList<YourType>());然后,您还需要显式同步这些对象.
这将确保操作顺序以阻塞为代价保持一致,并且您应始终获得最后的"正确"大小.
| 归档时间: |
|
| 查看次数: |
9319 次 |
| 最近记录: |