Product details
- Publisher : Packt Publishing (October 22, 2021)
- Language : English
- Paperback : 464 pages
- ISBN-10 : 1800208111
- ISBN-13 : 978-1800208117
کتاب The Art of Writing Efficient Programs: An advanced programmer's guide to efficient hardware utilization and compiler optimizations using C++ examples
Get to grips with various performance improvement techniques such as concurrency, lock-free programming, atomic operations, parallelism, and memory management
Key Features
- Understand the limitations of modern CPUs and their performance impact
- Find out how you can avoid writing inefficient code and get the best optimizations from the compiler
- Learn the tradeoffs and costs of writing high-performance programs
Book Description
The great free lunch of "performance taking care of itself" is over. Until recently, programs got faster by themselves as CPUs were upgraded, but that doesn't happen anymore. The clock frequency of new processors has almost peaked. New architectures provide small improvements to existing programs, but this only helps slightly. Processors do get larger and more powerful, but most of this new power is consumed by the increased number of processing cores and other "extra" computing units. To write efficient software, you now have to know how to program by making good use of the available computing resources, and this book will teach you how to do that.
The book covers all the major aspects of writing efficient programs, such as using CPU resources and memory efficiently, avoiding unnecessary computations, measuring performance, and how to put concurrency and multithreading to good use. You'll also learn about compiler optimizations and how to use the programming language (C++) more efficiently. Finally, you'll understand how design decisions impact performance.
By the end of this book, you'll not only have enough knowledge of processors and compilers to write efficient programs, but you'll also be able to understand which techniques to use and what to measure while improving performance. At its core, this book is about learning how to learn.
What you will learn
- Discover how to use the hardware computing resources in your programs effectively
- Understand the relationship between memory order and memory barriers
- Familiarize yourself with the performance implications of different data structures and organizations
- Assess the performance impact of concurrent memory accessed and how to minimize it
- Discover when to use and when not to use lock-free programming techniques
- Explore different ways to improve the effectiveness of compiler optimizations
- Design APIs for concurrent data structures and high-performance data structures to avoid inefficiencies
Who this book is for
This book is for experienced developers and programmers who work on performance-critical projects and want to learn different techniques to improve the performance of their code. Programmers who belong to algorithmic trading, gaming, bioinformatics, computational genomics, or computational fluid dynamics communities can learn various techniques from this book and apply them in their domain of work.
Although this book uses the C++ language, the concepts demonstrated in the book can be easily transferred or applied to other compiled languages such as C, Java, Rust, Go, and more.
Table of Contents
- Introduction to Performance and Concurrency
- Performance Measurements
- CPU Architecture, Resources, and Performance Implications
- Memory Architecture and Performance
- Threads, Memory, and Concurrency
- Concurrency and Performance
- Data Structures for Concurrency
- Concurrency in C++
- High-Performance C++
- Compiler Optimizations in C++
- Undefined Behavior and Performance
- Design for Performance
منابع کتاب کتاب The Art of Writing Efficient Programs: An advanced programmer's guide to efficient hardware utilization and compiler optimizations using C++ examples
با تکنیک های مختلف بهبود عملکرد مانند همزمانی، برنامه نویسی بدون قفل، عملیات اتمی، موازی سازی و مدیریت حافظه آشنا شوید.
ویژگی های کلیدی
- محدودیت های CPU های مدرن و تاثیر عملکرد آنها را درک کنید
- دریابید که چگونه می توانید از نوشتن کد ناکارآمد جلوگیری کنید و بهترین بهینه سازی ها را از کامپایلر دریافت کنید
- معاوضه ها و هزینه های نوشتن برنامه های با کارایی بالا را بیاموزید
توضیحات کتاب
ناهار رایگان عالی «مراقبت از خود عملکرد» به پایان رسید. تا همین اواخر، با ارتقاء CPUها، برنامه ها به خودی خود سریعتر می شدند، اما این دیگر اتفاق نمی افتد. فرکانس ساعت پردازنده های جدید تقریبا به اوج خود رسیده است. معماریهای جدید پیشرفتهای کوچکی در برنامههای موجود ایجاد میکنند، اما این فقط کمی کمک میکند. پردازندهها بزرگتر و قدرتمندتر میشوند، اما بیشتر این توان جدید توسط افزایش تعداد هستههای پردازشی و دیگر واحدهای محاسباتی «اضافی» مصرف میشود. برای نوشتن نرم افزار کارآمد، اکنون باید بدانید که چگونه با استفاده مناسب از منابع محاسباتی موجود، برنامه نویسی کنید، و این کتاب به شما یاد می دهد که چگونه این کار را انجام دهید.
این کتاب تمام جنبه های اصلی نوشتن برنامه های کارآمد را پوشش می دهد، مانند استفاده کارآمد از منابع CPU و حافظه، اجتناب از محاسبات غیر ضروری، اندازه گیری عملکرد، و نحوه استفاده مناسب از همزمانی و چند رشته ای. همچنین با بهینه سازی کامپایلر و نحوه استفاده کارآمدتر از زبان برنامه نویسی (C++) آشنا خواهید شد. در نهایت، متوجه خواهید شد که چگونه تصمیمات طراحی بر عملکرد تأثیر می گذارد.
در پایان این کتاب، شما نه تنها دانش کافی از پردازندهها و کامپایلرها برای نوشتن برنامههای کارآمد خواهید داشت، بلکه میتوانید درک کنید که از چه تکنیکهایی استفاده کنید و چه چیزی را در حین بهبود عملکرد اندازهگیری کنید. در اصل، این کتاب در مورد یادگیری نحوه یادگیری است.
آنچه خواهید آموخت
- نحوه استفاده موثر از منابع محاسباتی سخت افزاری در برنامه های خود را کشف کنید
- رابطه بین نظم حافظه و موانع حافظه را درک کنید
- با مفاهیم عملکردی ساختارهای داده و سازمان های مختلف آشنا شوید
- تاثیر عملکرد حافظه همزمان دسترسی و نحوه به حداقل رساندن آن را ارزیابی کنید
- کشف کنید که چه زمانی از تکنیک های برنامه نویسی بدون قفل استفاده کنید و چه زمانی استفاده نکنید
- راه های مختلف برای بهبود اثربخشی بهینه سازی کامپایلر را بررسی کنید
- طراحی API برای ساختارهای داده همزمان و ساختارهای داده با کارایی بالا برای جلوگیری از ناکارآمدی
این کتاب برای چه کسی است
این کتاب برای توسعه دهندگان و برنامه نویسان با تجربه ای است که روی پروژه های حیاتی عملکرد کار می کنند و می خواهند تکنیک های مختلفی را برای بهبود عملکرد کد خود یاد بگیرند. برنامه نویسانی که به انجمن های تجارت الگوریتمی، بازی، بیوانفورماتیک، ژنومیک محاسباتی یا دینامیک سیالات محاسباتی تعلق دارند، می توانند تکنیک های مختلفی را از این کتاب بیاموزند و آنها را در حوزه کاری خود به کار ببرند.
اگرچه این کتاب از زبان ++C استفاده می کند، اما مفاهیم نشان داده شده در کتاب را می توان به راحتی به سایر زبان های کامپایل شده مانند C، Java، Rust، Go و غیره منتقل یا اعمال کرد.
فهرست مطالب
- مقدمه ای بر عملکرد و همزمانی
- اندازه گیری عملکرد
- معماری CPU، منابع، و مفاهیم عملکرد
- معماری حافظه و عملکرد
- موضوعات، حافظه و همزمانی
- همزمانی و عملکرد
- ساختارهای داده برای همزمانی
- همزمانی در C++
- ++C با کارایی بالا
- بهینه سازی کامپایلر در C++
- رفتار و عملکرد تعریف نشده
- طراحی برای عملکرد
ارسال نظر درباره کتاب The Art of Writing Efficient Programs: An advanced programmer's guide to efficient hardware utilization and compiler optimizations using C++ examples