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)

Asynchronous streams

Asynchronous streams are the final missing piece in the task story that began several years ago when the Task class, async, and await were first introduced. An example of an unresolved use case is the processing of data chunks coming from the internet while they are being downloaded. The basic point here is that we don't want to await the entire stream of data, but instead take a single chunk at a time, processing it and then awaiting the next one. This processing can therefore happen while the other pieces of data are still downloading and the unused thread time can be spent to serve other users as well, incrementing the total scalability of the application.

Before digging into the new C# feature, let's rapidly review how an enumerable is made in the synchronous world. The following examples show an enumerable sequence that can be used inside a foreach statement; you may notice that the enumerated type is an integer instead of the hypothetical byte...