» » » » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

На нашем литературном портале можно бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю, Троелсен Эндрю . Жанр: Базы данных. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале litmir.org.
Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
Название: Язык программирования C#9 и платформа .NET5
Дата добавления: 22 август 2024
Количество просмотров: 172
Читать онлайн

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних просмотр данного контента СТРОГО ЗАПРЕЩЕН! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту readbookfedya@gmail.com для удаления материала

Язык программирования C#9 и платформа .NET5 читать книгу онлайн

Язык программирования C#9 и платформа .NET5 - читать бесплатно онлайн , автор Троелсен Эндрю

В 10-м издании книги описаны новейшие возможности языка C# 9 и .NET 5 вместе с подробным "закулисным" обсуждением, призванным расширить навыки критического мышления разработчиков, когда речь идет об их ремесле.

Книга охватывает ASP.NET Core, Entity Framework Core и многое другое наряду с последними обновлениями унифицированной платформы .NET, начиная с улучшений показателей производительности настольных приложений Windows в .NET 5 и обновления инструментария XAML и заканчивая расширенным рассмотрением файлов данных и способов обработки данных.

Все примеры кода были переписаны с учетом возможностей последнего выпуска C# 9.

Перейти на страницу:

В интерфейсах в C# 8 нельзя определять поля данных или нестатические конструкторы. Таким образом, следующая версия интерфейса IPointy приведет к разнообразным ошибкам на этапе компиляции:

<b>// Внимание! В этом коде полно ошибок!</b>

public interface IPointy

{

  // Ошибка! Интерфейсы не могут иметь поля данных!

  public int numbOfPoints;

  // Ошибка! Интерфейсы не могут иметь нестатические конструкторы!

  public IPointy() { numbOfPoints = 0;}

}

В начальной версии интерфейса IPointy определен единственный метод. В интерфейсных типах допускается также определять любое количество прототипов свойств. Например, интерфейс IPointy можно было бы обновить, как показано ниже, закомментировав свойство для чтения-записи и добавив свойство только для чтения. Свойство Points заменяет метод GetNumberOfPoints().

// Поведение &quot;наличия вершин&quot; в виде свойства только для чтения.

public interface IPointy

{

  // Неявно public и abstract.

  // byte GetNumberOfPoints();

  // Свойство, поддерживающее чтение и запись,

  // в интерфейсе может выглядеть так:

  // string PropName { get; set; }

  // Тогда как свойство только для записи - так:

   byte Points { get; }

}

На заметку! Интерфейсные типы также могут содержать определения событий (глава 12) и индексаторов (глава 11).

Сами по себе интерфейсные типы совершенно бесполезны, поскольку выделять память для них, как делалось бы для класса или структуры, невозможно:

// Внимание! Выделять память для интерфейсных типов не допускается!

IPointy p = new IPointy(); // Ошибка на этапе компиляции!

Интерфейсы не привносят ничего особого до тех пор, пока не будут реализованы классом или структурой. Здесь IPointy представляет собой интерфейс, который выражает поведение "наличия вершин". Идея проста: одни классы в иерархии фигур (например, Hexagon) имеют вершины, в то время как другие (вроде Circle) — нет.

Реализация интерфейса

Когда функциональность класса (или структуры) решено расширить за счет поддержки интерфейсов, к определению добавляется список нужных интерфейсов, разделенных запятыми. Имейте в виду, что непосредственный базовый класс должен быть указан первым сразу после операции двоеточия. Если тип класса порождается напрямую от System.Object, тогда вы можете просто перечислить интерфейсы, поддерживаемые классом, т.к. компилятор C# будет считать, что типы расширяют System.Object, если не задано иначе. К слову, поскольку структуры всегда являются производными от класса System.ValueType (см. главу 4), достаточно указать список интерфейсов после определения структуры. Взгляните на приведенные ниже примеры:

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

// Этот класс является производными от System.Object

// и реализует единственный интерфейс.

public class Pencil : IPointy

{...}

// Этот класс также является производными от System.Object

// и реализует единственный интерфейс.

public class SwitchBlade : object, IPointy

{...}

// Этот класс является производными от специального базового

// класса и реализует единственный интерфейс.

public class Fork : Utensil, IPointy

{...}

// Эта структура неявно является производной

// от System.ValueType и реализует два интерфейса.

public struct PitchFork : ICloneable, IPointy

{...}

Важно понимать, что для интерфейсных элементов, которые не содержат стандартной реализации, реализация интерфейса работает по плану "все или ничего". Поддерживающий тип не имеет возможности выборочно решать, какие члены он будет реализовывать. Учитывая, что интерфейс IPointy определяет единственное свойство только для чтения, накладные расходы невелики. Тем не менее, если вы реализуете интерфейс, который определяет десять членов (вроде показанного ранее IDbConnection), тогда тип отвечает за предоставление деталей для всех десяти абстрактных членов.

В текущем примере добавьте к проекту новый тип класса по имени Triangle, который "является" Shape и поддерживает IPointy. Обратите внимание, что реализация доступного только для чтения свойства Points (реализованного с использованием синтаксиса членов, сжатых до выражений) просто возвращает корректное количество вершин (т.е. 3):

using System;

namespace CustomInterfaces

{

  // Новый класс по имени Triangle, производный от Shape.

  class Triangle : Shape, IPointy

  {

    public Triangle() { }

    public Triangle(string name) : base(name) { }

    public override void Draw()

    {

      Console.WriteLine(&quot;Drawing {0} the Triangle&quot;, PetName);

    }

<b>    // Реализация IPointy.</b>

Перейти на страницу:
Комментариев (0)