Title :
A survey of concurrent priority queue algorithms
Author :
Kristijan Dragicevic;Daniel Bauer
Author_Institution :
IBM Research Laboratory Zurich, Switzerland
Abstract :
Algorithms for concurrent data structures have gained attention in recent years as multi-core processors have become unbiquitous. Using the example of a concurrent priority queue, this paper investigates different synchonization methods and concurrent algorithms. It covers traditional lock-based approaches, non-blocking algorithms as well as a method based on software transactional memory. Besides discussing correctness criteria for the various approaches, we also present performance results for all algorithms as well as a method based on software transactional memory. Besides discussing correctness criteria for the various approaches, we also present performance results for all algorithms for various scenarios. Somewhat surprisingly, we find that a simple lock-based approach performs reasonable well, even though it does not scale with the number of threads. Better scalability is achieved by non-blocking approaches.
Keywords :
"Data structures","Multicore processing","Software algorithms","Yarn","Scalability"
Conference_Titel :
Parallel and Distributed Processing, 2008. IPDPS 2008. IEEE International Symposium on
Print_ISBN :
978-1-4244-1693-6
DOI :
10.1109/IPDPS.2008.4536331