دانلود کتاب The Art of Writing Efficient Programs: An advanced programmer's guide to efficient hardware utilization and compiler optimizations using C++ examples
49,000 تومان
هنر نوشتن برنامه های کارآمد: راهنمای برنامه نویس پیشرفته برای استفاده کارآمد از سخت افزار و بهینه سازی کامپایلر با استفاده از مثال های C++
| موضوع اصلی | کامپیوتر – برنامه نویسی |
|---|---|
| نوع کالا | کتاب الکترونیکی |
| ناشر | Packt Publishing – ebooks Account |
| تعداد صفحه | 465 |
| حجم فایل | 6.60 مگابایت |
| کد کتاب | 1800208111 , 9781800208117 |
| نویسنده | Fedor G. Pikus |
|---|---|
| زبان | انگلیسی |
| فرمت | |
| سال انتشار | 2021 |
جدول کد تخفیف
| تعداد کتاب | درصد تخفیف | قیمت کتاب |
| 1 | بدون تخفیف | 25,000 تومان |
| 2 | 20 درصد | 20,000 تومان |
| 3 الی 5 | 25 درصد | 18,750 تومان |
| 6 الی 10 | 30 درصد | 17,500 تومان |
| 11 الی 20 | 35 درصد | 16,250 تومان |
| 21 الی 30 | 40 درصد | 15,000 تومان |
| 31 الی 40 | 45 درصد | 13,750 تومان |
| 41 الی 50 | 50 درصد | 12,500 تومان |
| 51 الی 70 | 55 درصد | 11,250 تومان |
| 71 الی 100 | 60 درصد | 10,000 تومان |
| 101 الی 150 | 65 درصد | 8,750 تومان |
| 151 الی 200 | 70 درصد | 7,500 تومان |
| 201 الی 300 | 75 درصد | 6,250 تومان |
| 301 الی 500 | 80 درصد | 5,000 تومان |
| 501 الی 1000 | 85 درصد | 3,750 تومان |
| 1001 الی 10000 | 90 درصد | 2,500 تومان |
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
ترجمه فارسی (ترجمه ماشینی)
با تکنیک های مختلف بهبود عملکرد مانند همزمانی، برنامه نویسی بدون قفل، عملیات اتمی، موازی سازی و مدیریت حافظه آشنا شوید
ویژگی های کلیدی
- محدودیتهای پردازندههای مرکزی مدرن و تأثیر عملکرد آنها را درک کنید
- دریابید که چگونه میتوانید از نوشتن کدهای ناکارآمد جلوگیری کنید و بهترین بهینهسازیها را از کامپایلر دریافت کنید
- معادل و هزینههای نوشتن بالا را بیاموزید. برنامه های اجرایی
توضیحات کتاب
ناهار رایگان عالی “مراقبت از عملکرد خود” به پایان رسید. تا همین اواخر، با ارتقاء CPUها، برنامه ها به خودی خود سریعتر می شدند، اما این دیگر اتفاق نمی افتد. فرکانس ساعت پردازنده های جدید تقریبا به اوج خود رسیده است. معماریهای جدید پیشرفتهای کوچکی در برنامههای موجود ایجاد میکنند، اما این فقط کمی کمک میکند. پردازندهها بزرگتر و قدرتمندتر میشوند، اما بیشتر این توان جدید توسط افزایش تعداد هستههای پردازشی و دیگر واحدهای محاسباتی «اضافی» مصرف میشود. برای نوشتن نرم افزار کارآمد، اکنون باید بدانید که چگونه با استفاده مناسب از منابع محاسباتی موجود، برنامه نویسی کنید، و این کتاب به شما یاد می دهد که چگونه این کار را انجام دهید.
این کتاب تمام جنبه های اصلی نوشتن را پوشش می دهد. برنامه های کارآمد، مانند استفاده بهینه از منابع CPU و حافظه، اجتناب از محاسبات غیر ضروری، اندازه گیری عملکرد، و نحوه استفاده مناسب از همزمانی و چند رشته ای. همچنین با بهینه سازی کامپایلر و نحوه استفاده کارآمدتر از زبان برنامه نویسی (C++) آشنا خواهید شد. در نهایت، متوجه خواهید شد که چگونه تصمیمات طراحی بر عملکرد تأثیر میگذارند.
در پایان این کتاب، نه تنها دانش کافی از پردازندهها و کامپایلرها برای نوشتن برنامههای کارآمد خواهید داشت، بلکه قادر خواهید بود برای درک اینکه از چه تکنیک هایی باید استفاده کرد و چه چیزی را در حین بهبود عملکرد اندازه گیری کرد. در اصل، این کتاب در مورد یادگیری نحوه یادگیری است.
آنچه یاد خواهید گرفت
- کشف نحوه استفاده موثر از منابع محاسباتی سخت افزاری در برنامه های خود
- درک رابطه بین نظم حافظه و موانع حافظه
- آشنا با مفاهیم عملکردی ساختارهای داده و سازمان های مختلف
- تأثیر عملکرد حافظه قابل دسترسی همزمان و نحوه به حداقل رساندن آن را ارزیابی کنید
- کشف کنید که چه زمانی از تکنیک های برنامه نویسی بدون قفل استفاده کنید و چه زمانی استفاده نکنید
- روش های مختلف را برای بهبود اثربخشی بهینه سازی کامپایلر کاوش کنید
- API های طراحی برای ساختارهای داده همزمان و داده های با کارایی بالا ساختارهایی برای جلوگیری از ناکارآمدی ها
این کتاب برای چه کسانی است
این کتاب برای توسعه دهندگان و برنامه نویسان با تجربه ای است که روی پروژه های حیاتی عملکردی کار می کنند و می خواهند تکنیک های مختلفی را برای بهبود عملکرد کد خود یاد بگیرند. برنامه نویسانی که به تجارت الگوریتمی، بازی، بیوانفورماتیک، ژنومیک محاسباتی یا دینامیک سیالات محاسباتی تعلق دارند، می توانند تکنیک های مختلفی را از این کتاب بیاموزند و آنها را در حوزه کاری خود به کار ببرند.
اگرچه این کتاب از زبان C++ استفاده می کند. مفاهیم نشان داده شده در کتاب را می توان به راحتی به سایر زبان های کامپایل شده مانند C، Java، Rust، Go و غیره منتقل کرد یا به کار برد.
فهرست محتوا
- مقدمه ای بر عملکرد و همزمانی
- اندازه گیری های عملکرد
- معماری CPU، منابع، و پیامدهای عملکرد
- معماری حافظه و عملکرد
- رشته ها، حافظه و همزمانی
- Concurrency و عملکرد
- ساختارهای داده برای Concurrency
- Concurrency در C++
- High-Performance C++
- بهینه سازی کامپایلر در C++
- C++ li>
- رفتار و عملکرد تعریف نشده
- طراحی برای عملکرد

نقد و بررسیها
هنوز بررسیای ثبت نشده است.