
arXiv: 1701.00854
The purpose of this book is to help you program shared-memory parallel systems without risking your sanity. Nevertheless, you should think of the information in this book as a foundation on which to build, rather than as a completed cathedral. Your mission, if you choose to accept, is to help make further progress in the exciting field of parallel programming-progress that will in time render this book obsolete. Parallel programming in the 21st century is no longer focused solely on science, research, and grand-challenge projects. And this is all to the good, because it means that parallel programming is becoming an engineering discipline. Therefore, as befits an engineering discipline, this book examines specific parallel-programming tasks and describes how to approach them. In some surprisingly common cases, these tasks can be automated. This book is written in the hope that presenting the engineering discipline underlying successful parallel-programming projects will free a new generation of parallel hackers from the need to slowly and painstakingly reinvent old wheels, enabling them to instead focus their energy and creativity on new frontiers. However, what you get from this book will be determined by what you put into it. It is hoped that simply reading this book will be helpful, and that working the Quick Quizzes will be even more helpful. However, the best results come from applying the techniques taught in this book to real-life problems. As always, practice makes perfect. But no matter how you approach it, we sincerely hope that parallel programming brings you at least as much fun, excitement, and challenge that it has brought to us!
662 pages. For a summary of changes since the v2021.12.22a version, please see https://paulmck.livejournal.com/69651.html. Other formats, including single-column and ebook-friendly, may be found here: https://mirrors.edge.kernel.org/pub/linux/kernel/people/paulmck/perfbook/perfbook.html
FOS: Computer and information sciences, D.1.3; D.4.1; D.4.8; E.1; F.1.2, D.1.3, Computer Science - Distributed, Parallel, and Cluster Computing, D.4.1, D.4.8, F.1.2, Distributed, Parallel, and Cluster Computing (cs.DC), E.1, 68-01, 68M20, 68N19, 68N25, 68N30
FOS: Computer and information sciences, D.1.3; D.4.1; D.4.8; E.1; F.1.2, D.1.3, Computer Science - Distributed, Parallel, and Cluster Computing, D.4.1, D.4.8, F.1.2, Distributed, Parallel, and Cluster Computing (cs.DC), E.1, 68-01, 68M20, 68N19, 68N25, 68N30
| selected citations These citations are derived from selected sources. This is an alternative to the "Influence" indicator, which also reflects the overall/total impact of an article in the research community at large, based on the underlying citation network (diachronically). | 0 | |
| popularity This indicator reflects the "current" impact/attention (the "hype") of an article in the research community at large, based on the underlying citation network. | Average | |
| influence This indicator reflects the overall/total impact of an article in the research community at large, based on the underlying citation network (diachronically). | Average | |
| impulse This indicator reflects the initial momentum of an article directly after its publication, based on the underlying citation network. | Average |
