
- •Вопрос 1 Классы обзор элементов класса.
- •Обзор элементов класса.
- •Вопрос 2 Методы. Синтаксический блок. Ссылочные параметры ref и out
- •Объявление методов
- •Возврат из метода и возврат значения
- •Вопрос 3 Перегрузка методов. Перегрузка методов. Вызов методов с одинаковым именем и разными аргументами
- •Вопрос 4 Переменное число аргументов метода params. Переменное число аргументов метода
- •Вопрос 5 Ссылочные параметры ref и out сравнительный анализ.
- •Вопрос 6 Конструкторы. Виды конструкторов, области применения, синтаксический блок.
- •Вызов конструктора экземпляра
- •Закрытые конструкторы экземпляра
- •Статические конструкторы
- •Конструкторы структур
- •Вопрос 7 Свойства. Область применения. Синтаксический блок.
- •Вопрос 8 Наследование. Предпосылки появления. Типы наследования. Синтаксический блок.
- •Вопрос 9 Виртуальные функции virtual. Вызов базовых версий функций base.
- •Вызов базовых версий функций
- •Вопрос 10 Наследование. Динамическое связывание.
- •Вопрос 11 Абстрактные методы. Особенности применения. Синтаксический блок
- •Абстрактный метод в c#
- •Вопрос 12 Абстрактные классы. Синтаксический блок. Особенности.
- •Вопрос 13 Полиморфизм как концепция ооп.
- •Вопрос 14 Потеря и восстановление информации о типе. Операторы is и as.
- •Вопрос 15 Множественное наследование. Интерфейсы область применения. Синтаксический блок.
- •Вопрос 16 Делегаты. Область применения. Синтаксический блок.
- •Вопрос 17 Групповые делегаты. Область применения. Особенности синтаксиса.
- •Вопрос 18 События. Область применения. Синтаксический блок.
- •Вопрос 19 Исключения. Область применения синтаксический блок.
- •Вопрос 20 Потоки данных и файловый ввод-вывод. Виды файлов.
- •Вопрос 21 Класс fileinfo. Обзор элементов класса.
- •Вопрос 22 Классы StreamReader и StreamWriter. Обзор элементов класса.
- •Вопрос 23 Класс List. Особенности применения. Методы и свойства класса.
- •Вопрос 24 Класс StringBuilder. Особенности применения и методы.
- •Вопрос 25 Бинарный ввод и вывод при помощи класса FileStream.
- •Вопрос 26 Форма как базовый элемент графического интерфейса. Заголовок, первоначальное размещение, свойства BackColor, ForeColor, Font; Cursor; BackGroundImage.
- •Вопрос 27 Форма как базовый элемент графического интерфейса. Рамка для формы. Кнопки изменения размеров формы. Прозрачность.
- •Вопрос 28 Передача фокуса ввода на форме. Свойства TabStop TabIndex.
- •Вопрос 29 Текстовые поля. Элемент управления Label и TextBox. Сравнительный анализ.
- •Вопрос 30 Элемент управления MenuStrip.
- •Вопрос 33
- •Вопрос 35 Элементы управления NumericUpDown и DomainUpDown характеристика и сравнительный анализ.
- •Вопрос 36 Вложенные элементы управления(контейнеры) TabControl и GroupBox. Применение элементов управления GroupBox и Panel
- •Применение элемента управления TabControl
- •Вопрос 37 Стыковка и фиксация элементов управления. Свойства Anchor и Dock.
- •Вопрос 38 Методы формы. Show, ShowDialog, Activate, Hide, Close. Методы Show и ShowDialog
- •Метод Activate
- •Метод Hide
- •Метод Close
- •Вопрос 42 Оповещение пользователя об ошибках ввода ErrorProvider.
Вопрос 13 Полиморфизм как концепция ооп.
Полиморфизм – это концепция ООП. В общем случае это означает возможность принимать множество форм. В программировании же это означает, возможность метода, реализованного для объекта указанного класса, вызываться автоматически, используя одну переменную для доступа к объектам разных классов посредствам механизма динамического связывания.
Рассмотрим пример. Предположим, что необходимо создать программу, которая позволила бы создать геометрические фигуры (круг, треугольник, прямоугольник).
Вначале постараемся определить классы, которые понадобятся в программе. Для этого перефразируем предложения, выделяя существительные: Чертеж состоит из набора фигур (Shape). Фигура может быть окружностью (Circle), прямоугольником (Rectangle), треугольником (Triangle) и т. д. Соответственно, нужно реализовать класс Shape и несколько подклассов. В данном случае достаточно ограничиться тремя подклассами: Circle, Rectangle и Triangle, как показано на рисунке.
По мере того как необходимо добавлять фигуры к чертежу, в программе создаются соответствующие объекты Shape (в данном случае Circles, Rectangles и Triangles). Свойства каждого объекта Shape сохраняются внутри него. Для хранения объектов необходимо создать соответствующий массив.
Как же разные объекты могут быть размещены в одном массиве, если все его элементы должны иметь один тип? Поскольку Circle, Square и Triangle — потомки Shape, любой из объектов этих трех типов может быть помещен в переменную типа Shape. Чтобы нарисовать объект, можно было бы написать метод в отдельном классе DrawingMachine и назвать его MakeDrawing. Этот метод перебирал бы объекты в массиве, просматривал значения их переменных экземпляра и определял позицию, размер и форму объекта. Такой подход был бы неудобен, поскольку параметры и алгоритмы рисования объектов различны. Например, окружности нужен радиус и координаты центра, прямоугольнику — высота и ширина, а более замысловатым формам может понадобиться и большее число параметров.
Здесь и стоит обратиться к полиморфизму. Полиморфизм позволяет реализовать следующую методику: вместо того, чтобы разбираться извне, как следует рисовать каждый объект, стоит позволить объекту самому поддерживать свой алгоритм рисования. Каждый объект будет инкапсулированным пакетом, содержащим данные и действия, необходимые для его отображения. Назовем метод, выводящий объект на экран, DrawYourself. Он нужен объекту любой формы, поэтому его необходимо объявить в классе Shape. Однако, неизвестна реализация DrawYourself для Shape. Поэтому DrawYourself нужно объявить abstract в классе Shape, а затем включить его реализацию в каждом из трех подклассов.
Напомним, что абстрактный метод одновременно виртуален, и если переопределить DrawYourself в каждом классе, производном от Shape, сработает механизм динамического связывания. Это означает, что для рисования объектов достаточно просто вызывать метод DrawYourself каждого из них. Механизм динамического связывания определит, Какого типа объект хранится в каждом элементе массива, и автоматически вызовет соответствующий метод DrawYourself.
Следует отметить, что DrawYourself объявлен abstract в классе Shape и переопределен в каждом из трех подклассов. Подклассы просты и не содержат информации о положении или размерах. Они просто выводят фигуру на экран.
Несмотря на то для переменной вызывается один и тот же метод DrawYourself из переменной myShape, благодаря механизму динамического связывания в каждой из них исполняется своя реализация метода DrawYourself. При вызове myShape.DrawYourself() программисту не приходится задумываться, какой объект хранится в myShape, и о других деталях. Полиморфизм позволяет рисовать чертеж на высоком уровне абстракции.