我有数据结构(即队列、堆栈或列表)。有无限循环(在线程1中)将对象插入到该数据结构中,还有另一个无限循环(在线程2中),它从该数据结构中获取对象并对其进行一些处理。我不希望处理循环阻止insert循环。
如何在Java中正确地实现这一点,以便在具有同步和来自两个不同线程的并发读写的两个线程之间共享一个单一的数据结构?java并发API (java 7)中是否有我可以使用的数据结构?是否有解决这个问题的建议?
发布于 2015-11-30 12:08:48
你要找的是一个非阻塞数据结构,ConcurrentLinkedQueue说。它将接受队列中的条目,并在没有阻塞的情况下向其请求,这使得它非常简单易用,而没有实现任何花哨的东西。
再读(非阻塞背后的理论)
发布于 2015-11-30 12:08:24
Java的ConcurrentLinkedQueue似乎是使用FIFO排序队列的最佳选择。
https://stackoverflow.com/questions/33998244
复制相似问题