The Art of Multiprocessor Programming
Read it now on the O’Reilly learning platform with a 10-day free trial.
O’Reilly members get unlimited access to books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.
Book description
The Art of Multiprocessor Programming promises to be the first comprehensive presentation of the principles and tools available for programming multiprocessor machines.
As the computer industry changes from single-processor to multiprocessor architectures, this revolution requires a fundamental change in how programs are written. To leverage the performance and power of multiprocessor programming, also known as multicore programming, programmers need to learn the new principles, algorithms, and tools.
The book will be of immediate use to programmers working with the new architectures. For example, the next generation of computer game consoles will all be multiprocessor-based, and the game industry is currently struggling to understand how to address the programming challenges presented by these machines. This change in the industry is so fundamental that it is certain to require a significant response by universities, and courses on multicore programming will become a staple of computer science curriculums.
This book includes fully-developed Java examples detailing data structures, synchronization techniques, transactional memory, and more.
Students in multiprocessor and multicore programming courses and engineers working with multiprocessor and multicore systems will find this book quite useful.
- The book on multicore programming, the new paradigm of computer science
- Written by the world's most revered experts in multiprocessor programming and performance
- Includes examples, models, exercises, PowerPoint slides, and sample Java programs
Table of contents
- Copyright
- Acknowledgments
- Preface
- 1. Introduction
-
I. Principles
- 2. Mutual Exclusion
- 3. Concurrent Objects
- 4. Foundations of Shared Memory
- 5. The Relative Power of Primitive Synchronization Operations
- 6. Universality of Consensus
-
II. Practice
- 7. Spin Locks and Contention
- 8. Monitors and Blocking Synchronization
- 9. Linked Lists: The Role of Locking
- 10. Concurrent Queues and the ABA Problem
- 11. Concurrent Stacks and Elimination
- 12. Counting, Sorting, and Distributed Coordination
- 13. Concurrent Hashing and Natural Parallelism
- 14. Skiplists and Balanced Search
- 15. Priority Queues
- 16. Futures, Scheduling, and Work Distribution
- 17. Barriers
-
18. Transactional Memory
- 18.1. Introduction
- 18.2. Transactions and Atomicity
- 18.3. Software Transactional Memory
- 18.4. Hardware Transactional Memory
- 18.5. Chapter Notes
- 18.6. Exercises
-
III. Appendix
- A. Software Basics
- B. Hardware Basics
- Bibliography
Product information
- Title: The Art of Multiprocessor Programming
- Author(s): Maurice Herlihy, Nir Shavit
- Release date: August 2011
- Publisher(s): Morgan Kaufmann
- ISBN: 9780080569581
You might also like
book
The Art of Multiprocessor Programming, Revised Reprint
by Maurice Herlihy, Nir Shavit
Revised and updated with improvements conceived in parallel programming courses, The Art of Multiprocessor Programming is …
book
The Art of Concurrency
by Clay Breshears
If you're looking to take full advantage of multi-core processors with concurrent programming, this practical book …
book
The Art of Writing Efficient Programs
by Fedor G. Pikus
Become a better programmer with performance improvement techniques such as concurrency, lock-free programming, atomic operations, parallelism, …
book
Algorithms in a Nutshell, 2nd Edition
by George T. Heineman, Gary Pollice, Stanley Selkow
Creating robust software requires the use of efficient algorithms, but programmers seldom think about them until …