Jump to ratings and reviews
Rate this book

Shared-Memory Synchronization

Rate this book
Since the advent of time sharing in the 1960s, designers of concurrent and parallel systems have needed to synchronize the activities of threads of control that share data structures in memory. In recent years, the study of synchronization has gained new urgency with the proliferation of multicore processors, on which even relatively simple user-level programs must frequently run in parallel. This lecture offers a comprehensive survey of shared-memory synchronization, with an emphasis on "systems-level" issues. It includes sufficient coverage of architectural details to understand correctness and performance on modern multicore machines, and sufficient coverage of higher-level issues to understand how synchronization is embedded in modern programming languages. The primary intended audience is "systems programmers"-the authors of operating systems, library packages, language run-time systems, concurrent data structures, and server and utility programs. Much of the discussion should also be of interest to application programmers who want to make good use of the synchronization mechanisms available to them, and to computer architects who want to understand the ramifications of their design decisions on systems-level code. Table of Contents: Introduction / Architectural Background / Essential Theory / Practical Spin Locks / Busy-wait Synchronization with Conditions / Read-mostly Atomicity / Synchronization and Scheduling / Nonblocking Algorithms / Transactional Memory / Author's Biography

264 pages, Paperback

First published November 1, 2012

22 people want to read

About the author

Michael L. Scott

8 books4 followers

Ratings & Reviews

What do you think?
Rate this book

Friends & Following

Create a free account to discover what your friends think of this book!

Community Reviews

5 stars
4 (100%)
4 stars
0 (0%)
3 stars
0 (0%)
2 stars
0 (0%)
1 star
0 (0%)
Displaying 1 of 1 review
Profile Image for Bugzmanov.
231 reviews97 followers
December 8, 2021
This book is short and to the point. Despite being quite dense, it's very approachable and is easy to follow. Code examples are written in a very clean and clear pseudocode that makes reading it a joy (god I wish all code in my dev experience was as clean).
Despite being "academic" I can't call it being dry, it has enough of illustrations and explanations that makes it a pretty entertaining.

This is definitely one of the best books on the topic that I've read. Overall it was a pleasant surprise.
Displaying 1 of 1 review

Can't find what you're looking for?

Get help and learn more about the design.