Book Image

Learn C# Programming

By : Marius Bancila, Raffaele Rialdi, Ankit Sharma
5 (1)
Book Image

Learn C# Programming

5 (1)
By: Marius Bancila, Raffaele Rialdi, Ankit Sharma

Overview of this book

The C# programming language is often developers’ primary choice for creating a wide range of applications for desktop, cloud, and mobile. In nearly two decades of its existence, C# has evolved from a general-purpose, object-oriented language to a multi-paradigm language with impressive features. This book will take you through C# from the ground up in a step-by-step manner. You'll start with the building blocks of C#, which include basic data types, variables, strings, arrays, operators, control statements, and loops. Once comfortable with the basics, you'll then progress to learning object-oriented programming concepts such as classes and structures, objects, interfaces, and abstraction. Generics, functional programming, dynamic, and asynchronous programming are covered in detail. This book also takes you through regular expressions, reflection, memory management, pattern matching, exceptions, and many other advanced topics. As you advance, you'll explore the .NET Core 3 framework and learn how to use the dotnet command-line interface (CLI), consume NuGet packages, develop for Linux, and migrate apps built with .NET Framework. Finally, you'll understand how to run unit tests with the Microsoft unit testing frameworks available in Visual Studio. By the end of this book, you’ll be well-versed with the essentials of the C# language and be ready to start creating apps with it.
Table of Contents (20 chapters)

Chapter 12: Multithreading and Asynchronous Programming

Since the very first personal computer, we have benefitted from the constant increase of CPU power—a phenomenon that heavily influenced developers' choices of tools, languages, and application design, while historically not putting much effort into programming to take advantage of multithreading.

On the hardware side, the prediction made by Moore's law that the density of the transistors in processors should double every 2 years, thus providing more computing power, worked for some decades, but we can already observe it slowing down. Even if the CPU manufacturers started producing multi-core CPUs roughly 20 years ago, the ability to execute code concurrently was primarily used by the operating systems (OSes) to make executing multiple processes smoother.

This doesn't mean that code was unable to leverage the power of concurrency, but just that only a small quantity of applications fully embraced the...