Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Введение в delphi

Содержание

История версийBorland Delphi 1 была предназначена для разработки под 16-разрядную платформу Win16;Начиная с Borland Delphi 2 компилируются программы под 32-разрядную платформу Win32;Вместе с Borland Delphi 6 выходит совместимая с ним по языку и библиотекам среда Kylix, предназначенная для компиляции программ под операционную систему Linux;С 2006
Введение в DelphiИстория версийОсновы ООПСтруктура класса История версийBorland Delphi 1 была предназначена для разработки под 16-разрядную платформу Win16;Начиная с История версийDelphi for .NET — среда разработки Delphi, а также язык Delphi (Object Pascal), ориентированные История версийВ 2008 году Embarcadero публикует пресс-релиз на Delphi for Win32 2009.Нововведения:По История версийВ 2009 году выходит интегрированная среда разработки Embarcadero Rad Studio 2010, Объектно-ориентированное программирование Объектно-ориентированное программирование (ООП)– это методология программирования, основанная на представлении программы в виде Объектно-ориентированное программирование (ООП)Основное преимущество ООП является возможность многократного использования программного кода. Объектно-ориентированное программированиеОбъект – это опознаваемый предмет, блок или сущность, имеющие важное функциональное Объектно-ориентированное программированиеОбъект обладает: состоянием, поведением и индивидуальностьюСостояние – перечень всех возможных свойств КлассыКлассы – это специальные типы, которые содержат поля, методы и свойства. Класс КлассыВажным отличием классов от других типов данных является то, что объекты класса КлассыКласс служит образцом для создания конкретных экземпляров – объектовЛюбой объект является экземпляром КлассыИнтерфейс класса соответствует его внешнему проявлению и подчеркивает его абстрактность. Реализация класса Объектно-ориентированное программированиеВ основе объектно-ориентированного программирования лежат три фундаментальных принципа:инкапсуляция наследование полиморфизм. ИнкапсуляцияДанныеМетоды обработки данных ИнкапсуляцияКласс представляет собой единство трех сущностей – полей, методов и свойств. Объединение ИнкапсуляцияИнкапсуляция полезна потому, что помогает перечислить связанные методы и данные под одной ИнкапсуляцияХорошо сконструированные объекты должны состоять из двух частей:	1) Данных и разделов реализации, скрытых НаследованиеЛюбой класс может быть порожден от другого класса. Для этого при его НаследованиеДочерний класс автоматически наследует поля, методы и свойства своего родителя и может НаследованиеВсе классы Object Pascal порождены от единственного родителя – класса TObject. Этот НаследованиеПрограммист не может создать класс, который бы не был дочерним классом TObject, НаследованиеПринцип наследования приводит к созданию ветвящегося дерева классов. Каждый потомок дополняет возможности ПолиморфизмПолиморфизм – это свойство классов решать схожие по смыслу проблемы различными способами. ПолимоорфизмМузыкальные инструментыУдарныеКлавишныеДуховыеСтрунныеИздают звукИздают звукИздают звукИздают звукИздают звук ПолиморфизмДля изменения метода необходимо перекрыть его в потомке, т.е. объявить в потомке Структура описания класса Структура описания классаType   TMyClass = class ПоляПолями называются инкапсулированные в класса данные. Поля могут быть любого типа, в ПоляКаждый объект получает уникальный набор значений полей, но общий для всех объектов Var MyObj1: TMyClass; …begin…  MyObj1.ffam:=’Иванов’;  MyObj1.fwidth:=500;…end; ПоляКласс-потомок получает все поля всех своих предков и может пополнить их своими, МетодыИнкапсулированные в классе процедуры и функции называются методами. Они объявляются, так же МетодыДля реализации методов нужно описать соответствующую подпрограмму в разделе реализации модуля. При МетодыImplemenation …procedure TForm1.FormClick(Sender:TObject);begin  {реализация метода FormClick}end;function TForm1.KeyDown:Word;begin  {реализация метода KeyDown}end;….end. МетодыДоступ к методам класса осуществляется с помощью составных имен:Var Form1: TForm1; Begin…Form1.FormClick(…)Key:= Form1.KeyDown;…End; СвойстваСвойства – это специальный механизм классов, регулирующий доступ к полям.При работе с СвойстваОбъявление свойства выполняется с помощью зарезервированных слов property, read, write.Обычно свойство связано СвойстваНапример,Type  TPeople = class    FName: string; СвойстваОбращение к свойствам выглядит в программе как обращение к полям: var People: СвойстваЕсли один из спецификаторов доступа опущен, то значение свойства можно либо только type   TPeople = class   FName: array of string; СвойстваВ отличии от полей свойства не имеют адреса в памяти, поэтому к СвойстваМетоды получения (чтения) и установки (записи) значений свойств подчиняются определенным правилам. Метод Свойстваtype  TPeople = class   FName: boolean;   procedure СвойстваИспользование методов для получения и установки свойств позволяет проверить корректность значения свойства, procedure TPeople.SetName(const AName: boolean);begin   if Name AName then Основные секции классаВ интерфейсе класса выделяются отдельные секции, определяющие область видимости элементов Основные секции классаPublic (общедоступная) – ее могут использовать все пользователи объектов данного Основные секции классаPublished (опубликованная) – часть класса, аналогичная общедоступной, но имеющая некоторые Unit Unit1;InterfaceUses Controls, Forms;Type	TForm1=class(TForm)	  Button1:TButton;   Private	  FintField: Integer; Unit unit2;InterfaceUses controls, unit1;Type TForm2=class(TForm1);  Button2:Tbutton;  Procedure Proc3(Sender:Tobject);	end;var	Form2: Tform2;ImplementationProcedure TForm2.Proc3(Sender:TObject);begin	Button2.Color Конструкторы и деструкторы Конструкторы и деструкторыВ состав любого класса входят два специальных метода – конструктор Конструкторы и деструкторыУ класса TObject эти методы называются Create и Destroy, так Type TMyClass = class IntField: Integer; Constructor Create (Value: Integer);	Destructor Destroy;End; …Constructor Create(Value: Обращение к конструктору должно предварять любое обращение к полям и некоторым методам Var MyObj: TMyClass;Begin MyObj.IntField := 0; 	 MyObj := TMyClass.Create;	 MyObj.IntField := Конструктор будет создавать объект, только если при вызове перед его именем указывается  …Constructor Create(Value: Integer); begin  IntField := Value;  If Value mod Если при объявлении класса конструктор / деструктор не описаны, то для создания/удаления Правила для реализации собственных конструкторов / деструкторовв конструкторе класса-потомка следует сначала вызвать Constructor TMyClass.Create (Value: Integer);begin Inherited Create;	 IntField := Value;	End;Возможная реализация конструктораВызываем унаследованный конструкторРеализуем дополнительные действия Destructor TMyClass.Destroy;begin …  Inherited Destroy;		End;Возможная реализация деструктораВызываем унаследованный деструкторРеализуем дополнительные действия Раннее и позднее связывание. Методы класса могут перекрываться в потомках. Потомок класса может иметь сходную по type TParent = class Fx, Fy:byte; constuctor MyConstr;  procedure WriteFields; end; var  _par: TParent;  _child: TChild;begin _par:= TParent.MyConstr; _child:=TChild.MyConstr; _par.WriteFields; _child.WriteFields;end.Вызов Важно понимать, что на этапе выполнения программы объект представляет собой единое целое, В Оbject Рascal объекту родительского класса можно присвоить любой дочерний объект. При Объект класса TObject совместим с любым другим объектом Delphi.Пример:var obj:TObject;  my_obj var  _par, _par1: TParent;  _child: TChild;begin _par:= TParent.MyConstr; _child:= TChild.MyConstr; Компилятор должен еще до выполнения программы решить какой метод вызывать, и вставить Чтобы вызываемые методы соответствовали типу объекта, необходимо отложить процесс связывания до этапа Для реализации динамического замещения методов, метод замещаемый в родительском классе, должен объявляться При каждом обращении к замещаемому методу компилятор вставляет код, позволяющий извлечь адрес Получив указание override, компилятор создаст код, который на этапе прогона программы поместит var  _par, _par1: TParent;  _child: TChild;begin _par:= TParent.MyConstr; _child:= TChild.MyConstr; В результате присваивания _par:=_child при вызове родительского метода WriteFields (_par.WriteFields) будет вызываться Разница между динамическими и виртуальными методами состоит в том, что DMT содержит type TParent = class Fx, Fy:byte; constuctor MyConstr;  procedure WriteFields; dynamic; type TParent = class Fx, Fy:byte; constuctor MyConstr;  procedure WriteFields; virtual; Вызов динамических и виртуальных методов выполняется через дополнительный этап получения адреса метода Виртуальные (динамические) методы базового класса определяет интерфейс всей иерархии.Этот интерфейс может расширяться Операции над классами. Для классов определены операции отношения = и . Кроме того, для классов Если A - объект, а C - класс, то выражение A as Наиболее часто операция as применяется к параметру Sender, передаваемому во все обработчики Выражение A is C позволяет определить, относится ли объект A к классу Абстрактные методы и классы. Абстрактные классыПри создании иерархии объектов для исключения повторяющегося кода часто бывает логично Абстрактные классыАбстрактные классы служат только для порождения потомковВ них задается набор методов, Абстрактные классыАбстрактные классы задают интерфейс для всей иерархииПри этом методам класса может Абстрактные методы объявляются с директивой abstracttype TParent = class procedure WriteFields; virtual; Абстрактные методыАбстрактные методы реализуются только в потомкахАбстрактные методы должны обязательно перекрываться в потомках //Реализация procedure TParent.WriteFields; begin  Write(‘No fields’); end; procedure TChild1.WriteFields; begin Методы класса. Методы классаНекоторые методы могут вызываться без создания и инициации объекта.Такие методы называются Методы классаДоступ к этим методам осуществляется через имя класса, а не имя Методы классаМетоды класса не должны обращаться к полям, т.к. в общем случае Одноименные методы Одноименные методыЧасто бывает, что методы, реализующие один и тот же алгоритм не Одноименные методыВ Delphi в рамках одного класса можно иметь несколько одноименных методов.Рассмотренный Одноименные методыИспользование нескольких методов с одним и тем же именем, но с Одноименные методыВажно:Чтобы одноименные методы можно было отличить друг от друга, каждый из Одноименные методыПри обнаружении одноименного метода компилятор Delphi предупреждает о том, что у Type TForm1 = class (TForm)	Button1 : TButton;	Button2 : TButton;	Button3 : TButton;	Button4 : implementation Procedure TForm1.Close(S: String);	Begin	  Caption := S;	End; Procedure TForm1.Close(I: Integer);	Begin	  Caption := Procedure TForm1.Button1Click (Sender: TObject); Begin  Close(‘Строка символов’);End; Procedure TForm1.Button2Click (Sender: TObject); Begin
Слайды презентации

Слайд 2 История версий
Borland Delphi 1 была предназначена для разработки

История версийBorland Delphi 1 была предназначена для разработки под 16-разрядную платформу Win16;Начиная

под 16-разрядную платформу Win16;
Начиная с Borland Delphi 2 компилируются программы

под 32-разрядную платформу Win32;
Вместе с Borland Delphi 6 выходит совместимая с ним по языку и библиотекам среда Kylix, предназначенная для компиляции программ под операционную систему Linux;
С 2006 года Borland передает подразделения, занимающиеся средствами разработки, своей дочерней компании CodeGear, которая в 2008 году была продана компании Embarcadero Technologies

Слайд 3 История версий
Delphi for .NET — среда разработки Delphi, а также язык

История версийDelphi for .NET — среда разработки Delphi, а также язык Delphi (Object Pascal),

Delphi (Object Pascal), ориентированные на разработку приложений для .NET.
Первая

версия полноценной среды разработки Delphi для .NET — Delphi 8. Она позволяла писать приложения только для .NET.
В Delphi 2006, можно писать приложения для .NET, используя стандартную библиотеку классов .NET, VCL для .NET. Delphi 2006 содержит функции для написания обычных приложений с использованием библиотек VCL и CLX.
Начиная с версии 2009, поддержка Delphi.NET была прекращена. Для разработки под .NET предлагается Delphi Prism.

Слайд 4 История версий
В 2008 году Embarcadero публикует пресс-релиз на

История версийВ 2008 году Embarcadero публикует пресс-релиз на Delphi for Win32

Delphi for Win32 2009.
Нововведения:
По умолчанию полная поддержка Юникода во всех частях

языка, VCL и RTL;
Обобщённые типы.
Анонимные методы.
Функция Exit теперь может принимать параметры в соответствии с типом функции.


Слайд 5 История версий
В 2009 году выходит интегрированная среда разработки

История версийВ 2009 году выходит интегрированная среда разработки Embarcadero Rad Studio

Embarcadero Rad Studio 2010, в которую вошла новая версия

Delphi 2010.
Новое в Delphi 2010
Delphi 2010 включает свыше 120 усовершенствований для повышения производительности.
IDE Insight в Delphi 2010 — мгновенный доступ к любой функции или параметру.
Классический интерфейс Delphi 7 и панель инструментов со вкладками как опция.
Расширение RTTI - поддержка атрибутов, которые могут быть применены к типам(в том числе классам и интерфейсам), полям, свойствам, методам и к элементам перечислений

Слайд 6 Объектно-ориентированное программирование

Объектно-ориентированное программирование

Слайд 7 Объектно-ориентированное программирование (ООП)
– это методология программирования, основанная на

Объектно-ориентированное программирование (ООП)– это методология программирования, основанная на представлении программы в

представлении программы в виде совокупности объектов, каждый из которых

является экземпляром определенного класса, а классы образуют иерархию наследования.


Слайд 8 Объектно-ориентированное программирование (ООП)

Основное преимущество ООП является возможность многократного

Объектно-ориентированное программирование (ООП)Основное преимущество ООП является возможность многократного использования программного кода.

использования программного кода.


Слайд 9 Объектно-ориентированное программирование

Объект – это опознаваемый предмет, блок или

Объектно-ориентированное программированиеОбъект – это опознаваемый предмет, блок или сущность, имеющие важное

сущность, имеющие важное функциональное значение в определенной области.


Слайд 10 Объектно-ориентированное программирование
Объект обладает: состоянием, поведением и индивидуальностью
Состояние –

Объектно-ориентированное программированиеОбъект обладает: состоянием, поведением и индивидуальностьюСостояние – перечень всех возможных

перечень всех возможных свойств объекты (Property) и их текущими

значениями
Поведение характеризует то, как один объект воздействует на другие или как он подвергается их воздействию в постоянно меняющихся условиях
Индивидуальность – свойство или набор свойств, благодаря которым различаются между собой объекты одного класса.

Слайд 11 Классы
Классы – это специальные типы, которые содержат поля,

КлассыКлассы – это специальные типы, которые содержат поля, методы и свойства.

методы и свойства.
Класс объявляется с помощью зарезервированного слова

class.

Type
TMyClass = class
{поля}…
{методы}…
{свойства}…
end;


Слайд 12 Классы
Важным отличием классов от других типов данных является

КлассыВажным отличием классов от других типов данных является то, что объекты

то, что объекты класса всегда располагаются в динамической памяти

(куче), поэтому объект-переменная представляет собой лишь указатель на динамическую область памяти. Однако при ссылке на содержимое объекта запрещается использовать символ «^» за именем объекта.

Слайд 13 Классы
Класс служит образцом для создания конкретных экземпляров –

КлассыКласс служит образцом для создания конкретных экземпляров – объектовЛюбой объект является

объектов

Любой объект является экземпляром класса.

Объявление экземпляра класса:

var
myClass: TMyClass;

Слайд 14 Классы
Интерфейс класса соответствует его внешнему проявлению и подчеркивает

КлассыИнтерфейс класса соответствует его внешнему проявлению и подчеркивает его абстрактность. Реализация

его абстрактность.
Реализация класса составляет его внутреннее проявление и

определяет особенность его поведения.


Слайд 15 Объектно-ориентированное программирование
В основе объектно-ориентированного программирования лежат три фундаментальных

Объектно-ориентированное программированиеВ основе объектно-ориентированного программирования лежат три фундаментальных принципа:инкапсуляция наследование полиморфизм.

принципа:
инкапсуляция
наследование
полиморфизм.


Слайд 16 Инкапсуляция
Данные
Методы обработки данных

ИнкапсуляцияДанныеМетоды обработки данных

Слайд 17 Инкапсуляция
Класс представляет собой единство трех сущностей – полей,

ИнкапсуляцияКласс представляет собой единство трех сущностей – полей, методов и свойств.

методов и свойств.
Объединение этих сущностей в единое целое

и называется инкапсуляцией.
Инкапсуляция позволяет во многом изолировать класс от остальных частей программы, сделать его «самодостаточным» для решения конкретной задачи.

Слайд 18 Инкапсуляция
Инкапсуляция полезна потому, что помогает перечислить связанные методы

ИнкапсуляцияИнкапсуляция полезна потому, что помогает перечислить связанные методы и данные под

и данные под одной эгидой, а так же скрывать

детали реализации, которые не требуют своей демонстрации или могут быть изменены в будущих версиях объекта.

Слайд 19 Инкапсуляция
Хорошо сконструированные объекты должны состоять из двух частей:
1) Данных

ИнкапсуляцияХорошо сконструированные объекты должны состоять из двух частей:	1) Данных и разделов реализации,

и разделов реализации, скрытых от программистов, использующих объект (с

целью защиты данных от несанкционированных изменений)
2) Набора интерфейсных элементов, предоставляющих возможность программистам обращаться со скрытыми методами и данными.

Слайд 20 Наследование
Любой класс может быть порожден от другого класса.

НаследованиеЛюбой класс может быть порожден от другого класса. Для этого при

Для этого при его объявлении указывается имя класса родителя:

TСhildClass

= class (TParentClass)


Слайд 21 Наследование
Дочерний класс автоматически наследует поля, методы и свойства

НаследованиеДочерний класс автоматически наследует поля, методы и свойства своего родителя и

своего родителя и может добавлять их новыми.
Таким образом,

принцип наследования обеспечивает поэтапное создание сложных классов и разработку собственных библиотек классов.

Слайд 22 Наследование
Все классы Object Pascal порождены от единственного родителя

НаследованиеВсе классы Object Pascal порождены от единственного родителя – класса TObject.

– класса TObject.
Этот класс не имеет полей и

свойств, но включает в себя методы самого общего назначения, обеспечивающие весь жизненный цикл любых объектов – от их создания до уничтожения.


Слайд 23 Наследование
Программист не может создать класс, который бы не

НаследованиеПрограммист не может создать класс, который бы не был дочерним классом

был дочерним классом TObject, т.к. следующие два объявления идентичны:

TMyClass=

class (TObject)
TMyClass= class


Слайд 24 Наследование
Принцип наследования приводит к созданию ветвящегося дерева классов.

НаследованиеПринцип наследования приводит к созданию ветвящегося дерева классов. Каждый потомок дополняет


Каждый потомок дополняет возможности своих родителей и передает их

своим потомкам.


Слайд 25 Полиморфизм
Полиморфизм – это свойство классов решать схожие по

ПолиморфизмПолиморфизм – это свойство классов решать схожие по смыслу проблемы различными

смыслу проблемы различными способами.
В рамках Delphi поведение класса

определяется набором входящих в него методов.
Изменяя алгоритм того или иного метода в потомках класса, можно придавать этим потомкам отсутствующие у родителя специфические свойства.

Слайд 26 Полимоорфизм
Музыкальные инструменты
Ударные
Клавишные
Духовые
Струнные
Издают звук
Издают звук
Издают звук
Издают звук
Издают звук

ПолимоорфизмМузыкальные инструментыУдарныеКлавишныеДуховыеСтрунныеИздают звукИздают звукИздают звукИздают звукИздают звук

Слайд 27 Полиморфизм
Для изменения метода необходимо перекрыть его в потомке,

ПолиморфизмДля изменения метода необходимо перекрыть его в потомке, т.е. объявить в

т.е. объявить в потомке одноименный метод и реализовать в

нем нужные действия. В результате в объекте- родителе и объекте-потомке будут действовать два одноименных метода, имеющих различные алгоритмы.
Полиморфизм достигается также виртуализацией методов, позволяющей родительским методам обращаться к методам своих потомков.

Слайд 28 Структура описания класса

Структура описания класса

Слайд 29 Структура описания класса
Type
TMyClass = class

Структура описания классаType  TMyClass = class   {поля}…

{поля}…

{методы}…
{свойства}…
end;


Слайд 30 Поля
Полями называются инкапсулированные в класса данные. Поля могут

ПоляПолями называются инкапсулированные в класса данные. Поля могут быть любого типа,

быть любого типа, в том числе классами. Принято имя

поля начинать с буквы F (Field). Например:
type
TMyClass = class(TForm)
FInt:integer;
fWidth:word;
FPrim1:TObject;
fFam:string;
end;


Слайд 31 Поля
Каждый объект получает уникальный набор значений полей, но

ПоляКаждый объект получает уникальный набор значений полей, но общий для всех

общий для всех объектов для данного класса набор методов

и свойств.
Понятие инкапсуляции и хороший стиль объектно-ориентированного программирования требуют, чтобы обращение к полям объектов выполнялось исключительно посредством методов.
Однако в Delphi разрешается обращаться к полям и напрямую. Для этого используются составные имена полей:

Слайд 32 Var MyObj1: TMyClass;
 

begin

MyObj1.ffam:=’Иванов’;
MyObj1.fwidth:=500;

end;

Var MyObj1: TMyClass; …begin… MyObj1.ffam:=’Иванов’; MyObj1.fwidth:=500;…end;

Слайд 33 Поля
Класс-потомок получает все поля всех своих предков и

ПоляКласс-потомок получает все поля всех своих предков и может пополнить их

может пополнить их своими, но он не может переопределить

их или удалить.

Слайд 34 Методы
Инкапсулированные в классе процедуры и функции называются методами.

МетодыИнкапсулированные в классе процедуры и функции называются методами. Они объявляются, так

Они объявляются, так же как и обычные подпрограммы:
type
TForm1

= class(TForm)
procedure FormClick(Sender: TObject);
function KeyDown : Word;
end;


Слайд 35 Методы
Для реализации методов нужно описать соответствующую подпрограмму в

МетодыДля реализации методов нужно описать соответствующую подпрограмму в разделе реализации модуля.

разделе реализации модуля. При этом в заголовке метода указывается

название класса.

Слайд 36 Методы
Implemenation

procedure TForm1.FormClick(Sender:TObject);
begin
{реализация метода FormClick}
end;

function TForm1.KeyDown:Word;
begin

МетодыImplemenation …procedure TForm1.FormClick(Sender:TObject);begin {реализация метода FormClick}end;function TForm1.KeyDown:Word;begin {реализация метода KeyDown}end;….end.

{реализация метода KeyDown}
end;
….
end.


Слайд 37 Методы
Доступ к методам класса осуществляется с помощью составных

МетодыДоступ к методам класса осуществляется с помощью составных имен:Var Form1: TForm1; Begin…Form1.FormClick(…)Key:= Form1.KeyDown;…End;

имен:

Var Form1: TForm1;
 
Begin

Form1.FormClick(…)
Key:= Form1.KeyDown;

End;


Слайд 38 Свойства
Свойства – это специальный механизм классов, регулирующий доступ

СвойстваСвойства – это специальный механизм классов, регулирующий доступ к полям.При работе

к полям.
При работе с объектом свойства выглядят как поля:

они принимают значения и участвуют в выражениях.
Но в отличии от полей свойства не занимают место в памяти, а операции их чтения и записи ассоциируются с обычными полями и методами.
Это позволяет создавать необходимые сопутствующие эффекты при обращении к свойствам.

Слайд 39 Свойства
Объявление свойства выполняется с помощью зарезервированных слов property,

СвойстваОбъявление свойства выполняется с помощью зарезервированных слов property, read, write.Обычно свойство

read, write.

Обычно свойство связано с некоторым полем и указывает

те методы класса, которые должны использоваться при записи в это поле или при чтении из него.

Слайд 40 Свойства
Например,
Type
TPeople = class FName:

СвойстваНапример,Type TPeople = class  FName: string;  procedure GetName;

string; procedure GetName; property Name:

string read FName write GetName; end;


Слайд 41 Свойства
Обращение к свойствам выглядит в программе как обращение

СвойстваОбращение к свойствам выглядит в программе как обращение к полям: var

к полям:

var People: TPeople; Get: string; ... People.Name := 'Сергей'; Get

:= People.Name;

Слайд 42 Свойства
Если один из спецификаторов доступа опущен, то значение

СвойстваЕсли один из спецификаторов доступа опущен, то значение свойства можно либо

свойства можно либо только читать (задан спецификатор read), либо

только записывать (задан спецификатор write).



Слайд 43 type
TPeople = class FName:

type  TPeople = class  FName: array of string;

array of string; function GetName: integer; property

Name: integer read GetName; end;

function TPeople.GetName: integer; begin Result := Length(FName); end;

Слайд 44 Свойства
В отличии от полей свойства не имеют адреса

СвойстваВ отличии от полей свойства не имеют адреса в памяти, поэтому

в памяти, поэтому к ним запрещено применять операцию @.


Как следствие, их нельзя передавать в var- и out-параметрах процедур и функций.
Технология объектно-ориентированного программирования в среде Delphi предписывает избегать прямого обращения к полям, создавая вместо этого соответствующие свойства.

Слайд 45 Свойства
Методы получения (чтения) и установки (записи) значений свойств

СвойстваМетоды получения (чтения) и установки (записи) значений свойств подчиняются определенным правилам.

подчиняются определенным правилам.
Метод чтения свойства - это всегда

функция, возвращающая значение того же типа, что и тип свойства.
Метод записи свойства - это обязательно процедура, принимающая параметр того же типа, что и тип свойства.
В остальных отношениях это обычные методы объекта.


Слайд 46 Свойства
type
TPeople = class FName:

Свойстваtype  TPeople = class  FName: boolean;  procedure SetName(const

boolean;
procedure SetName(const AName: boolean); function GetName:

integer;
property Name: boolean read FName write SetName; property Count: integer read GetName; end;


Слайд 47 Свойства
Использование методов для получения и установки свойств позволяет

СвойстваИспользование методов для получения и установки свойств позволяет проверить корректность значения

проверить корректность значения свойства, сделать дополнительные вычисления, установить значения

зависимых полей и так далее.


Слайд 48 procedure TPeople.SetName(const AName: boolean);
begin if Name

procedure TPeople.SetName(const AName: boolean);begin  if Name AName then

AName then begin

if FName then // Если состояние изменяется то
... else ...
FName := AName; // Сохранение состояния в поле
end; end;


Слайд 49 Основные секции класса
В интерфейсе класса выделяются отдельные секции,

Основные секции классаВ интерфейсе класса выделяются отдельные секции, определяющие область видимости

определяющие область видимости элементов класса.
Внутри каждой секции вначале

определяются поля, а затем методы и свойства.

Слайд 50 Основные секции класса
Public (общедоступная) – ее могут использовать

Основные секции классаPublic (общедоступная) – ее могут использовать все пользователи объектов

все пользователи объектов данного класса;
Private (личная) – может

использоваться внутри реализации данного класса;
Protected (защищенная) – доступна только классам, которые являются потомками данного класса, а также методам самого класса;

Слайд 51 Основные секции класса
Published (опубликованная) – часть класса, аналогичная

Основные секции классаPublished (опубликованная) – часть класса, аналогичная общедоступной, но имеющая

общедоступной, но имеющая некоторые особенности в реализации. В ней

перечисляются свойства, которые доступны не только на этапе исполнения, но и на этапе конструирования программы (т.е. в окне Инспектора Объектов). Она используется только при разработке нестандартных компонентов

Слайд 52 Unit Unit1;
Interface
Uses Controls, Forms;
Type
TForm1=class(TForm)
Button1:TButton;

Unit Unit1;InterfaceUses Controls, Forms;Type	TForm1=class(TForm)	 Button1:TButton;  Private	 FintField: Integer;	 Procedure SetValue(Value:

Private
FintField: Integer;
Procedure SetValue(Value: Integer);

Function GetValue: Integer;
Published
Property IntField: read GetValue write SetValue;
Protected
Procedure Proc1;
Public
Procedure Proc2;
end;
 var
Form1: TForm1;

Implementation
Procedure TForm1.Proc1;
begin
button1.color := clBtnFace;
FintField := 0;
IntField := 0;
Proc1;
Proc2;
end;
 
begin
Form1.button1.color := clBtnFace;
Form1.FintField := 0
Form1.IntField := 0;
Form1.Proc1;
Form1.Proc2;
end.

//ошибка


Слайд 53 Unit unit2;
Interface
Uses controls, unit1;
Type
TForm2=class(TForm1);
Button2:Tbutton;

Unit unit2;InterfaceUses controls, unit1;Type TForm2=class(TForm1); Button2:Tbutton; Procedure Proc3(Sender:Tobject);	end;var	Form2: Tform2;ImplementationProcedure TForm2.Proc3(Sender:TObject);begin	Button2.Color :=

Procedure Proc3(Sender:Tobject);
end;
var
Form2: Tform2;

Implementation
Procedure TForm2.Proc3(Sender:TObject);
begin
Button2.Color := clBTNFace;
FintField := 0;
IntField

:= 0;
Proc1;
Proc2;
end;
 
begin
Form1.button1.color := clBtnFace;
Form1.FintField := 0;
Form1.IntField := 0;
Form1.proc1;
Form1.proc2;
end.

//ошибка

//ошибка


Слайд 54 Конструкторы и деструкторы

Конструкторы и деструкторы

Слайд 55 Конструкторы и деструкторы
В состав любого класса входят два

Конструкторы и деструкторыВ состав любого класса входят два специальных метода –

специальных метода – конструктор и деструктор.
Конструктор распределят объект

в динамической памяти и помещает адрес этой памяти в переменную Self, которая автоматически объявляется в классе.
Деструктор удаляет объект из кучи.

Слайд 56 Конструкторы и деструкторы
У класса TObject эти методы называются

Конструкторы и деструкторыУ класса TObject эти методы называются Create и Destroy,

Create и Destroy, так же они называются в подавляющем

большинстве его потомков.
По своей форме конструкторы и деструкторы являются процедурами, но объявляются с помощью зарезервированных слов Constructor и Destructor

Слайд 57 Type
TMyClass = class
IntField: Integer;
Constructor Create

Type TMyClass = class IntField: Integer; Constructor Create (Value: Integer);	Destructor Destroy;End; …Constructor

(Value: Integer);
Destructor Destroy;
End;
 …
Constructor Create(Value: Integer);
begin
IntField

:= Value;
end; 

Destructor Destroy;
begin

end;


Слайд 58 Обращение к конструктору должно предварять любое обращение к

Обращение к конструктору должно предварять любое обращение к полям и некоторым

полям и некоторым методам объекта.
В базовом классе TObject определен

метод Free, который сначала проверяет действительность адреса объекта и лишь затем вызывает деструктор Destroy.
Обращение к деструктору объекта будет ошибочным, если объект не создан конструктором, поэтому для уничтожения ненужного объекта следует вызывать метод Free

Конструкторы и деструкторы


Слайд 59 Var
MyObj: TMyClass;
Begin
MyObj.IntField := 0;

MyObj

Var MyObj: TMyClass;Begin MyObj.IntField := 0; 	 MyObj := TMyClass.Create;	 MyObj.IntField

:= TMyClass.Create;

MyObj.IntField := 0;
 
. .

. . .
MyObj.Free;
 
End;

Ошибка! Объект не создан конструктором

Вызов конструктора. Создаем объект в памяти

Правильное обращение к полю

Уничтожаем ненужный объект


Слайд 60 Конструктор будет создавать объект, только если при вызове

Конструктор будет создавать объект, только если при вызове перед его именем

перед его именем указывается имя класса.
Если же указывается имя

существующего объекта, то создание объекта не происходит, а лишь выполняется код, содержащийся в теле конструктора

Конструкторы и деструкторы


Слайд 61  …
Constructor Create(Value: Integer);
begin
IntField := Value;

 …Constructor Create(Value: Integer); begin IntField := Value; If Value mod 3

If Value mod 3 = 0 then

IntField := IntField div 3;
end; 
 …
Var
Obj1, Obj2:TMyClass;
begin 

Obj1.Create(5);

Obj2 := TMyClass.Create(4);

Obj2.Create(6);
end.

Ошибка! Объект Obj1 не существует

Создаем Obj2

Выполняем действия конструктора


Слайд 62 Если при объявлении класса конструктор / деструктор не

Если при объявлении класса конструктор / деструктор не описаны, то для

описаны, то для создания/удаления будут вызываться соответствующие методы родительского

класса.
Т.к. все классы наследуются от TObject, то любой класс имеет конструктор/деструктор по умолчанию
Создавайте свои конструкторы/деструкторы, только если требуются дополнительные действия по инициализации или удалению объектов

Конструкторы и деструкторы


Слайд 63 Правила для реализации собственных конструкторов / деструкторов
в конструкторе

Правила для реализации собственных конструкторов / деструкторовв конструкторе класса-потомка следует сначала

класса-потомка следует сначала вызвать конструктор своего родителя, а уже

затем осуществлять дополнительные действия.
В последней строке деструктора необходимо вызвать деструктор класса-предка
Вызов любого метода родительского класса достигается с помощью зарезервированного слова Inherited (Унаследованный).

Конструкторы и деструкторы


Слайд 64


Constructor TMyClass.Create (Value: Integer);

begin
Inherited Create;
IntField :=

Constructor TMyClass.Create (Value: Integer);begin Inherited Create;	 IntField := Value;	End;Возможная реализация конструктораВызываем унаследованный конструкторРеализуем дополнительные действия

Value;
End;

Возможная реализация конструктора
Вызываем унаследованный конструктор
Реализуем дополнительные действия


Слайд 65


Destructor TMyClass.Destroy;

begin

Inherited Destroy;
End;

Возможная реализация деструктора
Вызываем

Destructor TMyClass.Destroy;begin … Inherited Destroy;		End;Возможная реализация деструктораВызываем унаследованный деструкторРеализуем дополнительные действия

унаследованный деструктор
Реализуем дополнительные действия


Слайд 66 Раннее и позднее связывание.

Раннее и позднее связывание.

Слайд 67 Методы класса могут перекрываться в потомках.
Потомок класса

Методы класса могут перекрываться в потомках. Потомок класса может иметь сходную

может иметь сходную по названию процедуру или функцию, которая

будет выполнять другое действие.
В Оbject Рascal возможно статическое и динамическое замещение методов.

Слайд 68 type
TParent = class
Fx, Fy:byte;
constuctor MyConstr;

type TParent = class Fx, Fy:byte; constuctor MyConstr; procedure WriteFields; end;


procedure WriteFields;
end;

TChild = class(TParent)
Fz:

byte;
constuctor MyConstr;
procedure WriteFields;
end;

Constructor TParent.MyConstr;
begin
inherited Create;
Fx := 0;
Fy := 0;
end;

procedure TParent.WriteFields;
begin
Writeln(Fx,’ ‘, Fy);
end;

Constructor TChild.MyConstr;
begin
inherited MyConstr;
Fz := 100;
end;

procedure TChild.WriteFields;
begin
Writeln(Fx, ‘ ’, Fy, ‘ ’, Fz);
end;


Слайд 69 var
_par: TParent;
_child: TChild;

begin

var  _par: TParent; _child: TChild;begin _par:= TParent.MyConstr; _child:=TChild.MyConstr; _par.WriteFields; _child.WriteFields;end.Вызов

_par:= TParent.MyConstr;

_child:=TChild.MyConstr;

_par.WriteFields;

_child.WriteFields;

end.
Вызов родительского метода:

WriteFields
Результат: 0 0

Вызов дочернего метода: WriteFields
Результат: 0 0 100

Объявляем экземпляры классов TParent и TChild


Слайд 70 Важно понимать, что на этапе выполнения программы объект

Важно понимать, что на этапе выполнения программы объект представляет собой единое

представляет собой единое целое, не разделенное на части предка

и потомка.

Во время выполнения программы объекты хранятся в отдельных переменных, массивах и др.
Во многих случаях удобно оперировать объектами одной иерархии единообразно, то есть использовать один и тот же программный код для работы с экземплярами разных классов.


Слайд 71 В Оbject Рascal объекту родительского класса можно присвоить

В Оbject Рascal объекту родительского класса можно присвоить любой дочерний объект.

любой дочерний объект.
При этом все поля, свойства и

методы родительского объекта будут заполнены правильно.
Обратное утверждение НЕВЕРНО.

_par:=_child;

При этом присваивании все поля, методы и свойства, которые не входят в TParent игнорируются


Слайд 72 Объект класса TObject совместим с любым другим объектом

Объект класса TObject совместим с любым другим объектом Delphi.Пример:var obj:TObject; my_obj

Delphi.

Пример:
var obj:TObject;
my_obj : TChild;

obj := my_obj;

my_obj

:= obj;

возможность доступа к элементам класса определяется типом ссылки, а не типом объекта, на который он указывает.

Допустимое присваивание

Ошибка! Недопустимое присваивание


Слайд 73 var
_par, _par1: TParent;
_child:

var  _par, _par1: TParent; _child: TChild;begin _par:= TParent.MyConstr; _child:= TChild.MyConstr;

TChild;

begin
_par:= TParent.MyConstr;
_child:= TChild.MyConstr;

_par.WriteFields;
_child.WriteFields;


_par :=

_child;
_par1 := TChild.MyConstr;

_par.WriteFields;
_par1.WriteFields;
end.

Вызов родительского метода: WriteFields
Результат: 0 0

Вызов дочернего метода: WriteFields
Результат: 0 0 100

Вызов родительского метода: WriteFields
Результат: 0 0
Результат: 0 0


Слайд 74 Компилятор должен еще до выполнения программы решить какой

Компилятор должен еще до выполнения программы решить какой метод вызывать, и

метод вызывать, и вставить в код фрагмент, передающий управление

на этот метод.
Этот процесс называется ранним связыванием (статическое замещение методов) .
При этом компилятор может руководствоваться только типом переменной, для которой вызывается метод или свойство.
То, что в этой переменной в разные моменты времени могут находиться ссылки на объекты разных типов, компилятор учесть не может.


Слайд 75 Чтобы вызываемые методы соответствовали типу объекта, необходимо отложить

Чтобы вызываемые методы соответствовали типу объекта, необходимо отложить процесс связывания до

процесс связывания до этапа выполнения программы, а точнее до

момента вызова метода, когда уже точно известно, на объект какого типа указывает ссылка.
Такой механизм называется поздним связыванием (динамическое замещение методов) и реализуется с помощью так называемых виртуальных (или динамических) методов.



Слайд 76 Для реализации динамического замещения методов, метод замещаемый в

Для реализации динамического замещения методов, метод замещаемый в родительском классе, должен

родительском классе, должен объявляться как динамический (с директивой dynamic)

или виртуальный (с директивой virtual).
Для реализации позднего связывания необходимо, чтобы адреса виртуальных и динамических методов хранились там, где ими можно будет в любой момент воспользоваться.
Поэтому компилятор формирует специальные таблицы: таблицу виртуальных методов (Virtual Method Table, VMT) и таблицу динамических методов (Dynamic Method Table, DMT)




Слайд 77 При каждом обращении к замещаемому методу компилятор вставляет

При каждом обращении к замещаемому методу компилятор вставляет код, позволяющий извлечь

код, позволяющий извлечь адрес нужного метода из той или

иной таблицы
В классе-потомке замещающий метод объявляется с директивой override (перекрыть)

type
TParent = class
Fx, Fy:byte;
constuctor MyConstr;
procedure WriteFields; virtual;
end;

TChild = class(TParent)
Fz: byte;
procedure WriteFields; override;
end;

Слайд 78 Получив указание override, компилятор создаст код, который на

Получив указание override, компилятор создаст код, который на этапе прогона программы

этапе прогона программы поместит в родительскую таблицу точку входа

метода класса-потомка, что позволит родителю выполнить нужное действие с помощью нового метода.




Слайд 79 var
_par, _par1: TParent;
_child:

var  _par, _par1: TParent; _child: TChild;begin _par:= TParent.MyConstr; _child:= TChild.MyConstr;

TChild;

begin
_par:= TParent.MyConstr;
_child:= TChild.MyConstr;

_par.WriteFields;
_child.WriteFields;


_par :=

_child;
_par1 := TChild.MyConstr;

_par.WriteFields;
_par1.WriteFields;
end.

Вызов родительского метода: WriteFields
Результат: 0 0

Вызов дочернего метода: WriteFields
Результат: 0 0 100

Вызов дочернего метода: WriteFields
Результат: 0 0 100
Результат: 0 0 100


Слайд 80 В результате присваивания _par:=_child
при вызове родительского метода

В результате присваивания _par:=_child при вызове родительского метода WriteFields (_par.WriteFields) будет

WriteFields (_par.WriteFields) будет вызываться метод WriteFields дочернего класса.
Однако

нельзя вызвать ни один из методов дочернего объекта, который не принадлежит родительскому.


Слайд 81 Разница между динамическими и виртуальными методами состоит в

Разница между динамическими и виртуальными методами состоит в том, что DMT

том, что DMT содержит адреса динамических методов только данного

класса
В то время как таблица VMT содержит адреса виртуальных методов не только данного класса, но и всех его родителей
Значительно большая по размеру таблица VMT обеспечивает более быстрый поиск, в то время как при обращении к динамическому методу программа сначала просматривает таблицу DMT у объекта, затем – у его родителя и т.д., пока не будет найдена нужная реализация метода




Слайд 82 type
TParent = class
Fx, Fy:byte;
constuctor MyConstr;

type TParent = class Fx, Fy:byte; constuctor MyConstr; procedure WriteFields; dynamic;


procedure WriteFields; dynamic;
end;

TChild = class(TParent)

Fz: byte;
procedure WriteFields; override;
end;

Слайд 83 type
TParent = class
Fx, Fy:byte;
constuctor MyConstr;

type TParent = class Fx, Fy:byte; constuctor MyConstr; procedure WriteFields; virtual;


procedure WriteFields; virtual;
end;

TChild = class(TParent)

Fz: byte;
procedure WriteFields; override;
end;

Слайд 84 Вызов динамических и виртуальных методов выполняется через дополнительный

Вызов динамических и виртуальных методов выполняется через дополнительный этап получения адреса

этап получения адреса метода из таблиц DMT и VMT,

что несколько замедляет выполнение программы.

Важно: Переопределенный метод должен обладать таким же набором параметров, как и одноименный метод базового класса




Слайд 85 Виртуальные (динамические) методы базового класса определяет интерфейс всей

Виртуальные (динамические) методы базового класса определяет интерфейс всей иерархии.Этот интерфейс может

иерархии.
Этот интерфейс может расширяться в потомках за счет добавления

новых виртуальных (динамических) методов
Переопределять виртуальный (динамический) метод в каждом из потомком не обязательно: если он выполняет устраивающие потомка действия, метод наследуется.

С помощью виртуальных (динамических) методов реализуется полиморфизм.


Слайд 86 Операции над классами.

Операции над классами.

Слайд 87 Для классов определены операции отношения = и .

Для классов определены операции отношения = и . Кроме того, для


Кроме того, для классов определены еще две операции: as

(как) и is (является).
Первым операндом в обеих операциях является объект, вторым - класс.

объект as класс

объект is класс


Слайд 88 Если A - объект, а C - класс,

Если A - объект, а C - класс, то выражение A

то выражение A as C возвращает тот же самый

объект, но рассматриваемый как объект класса C.
Операция даст результат, если указанный класс C является классом объекта A или одним из наследников этого класса.
В противном случае будет сгенерировано исключение.

Слайд 89 Наиболее часто операция as применяется к параметру Sender,

Наиболее часто операция as применяется к параметру Sender, передаваемому во все

передаваемому во все обработчики событий как объект - источник

события и имеющему тип TObject, в котором очень мало свойств для идентификации объекта.

Например:
if (Sender as TComponent).Name = 'Button2' then ...;

Слайд 90 Выражение A is C позволяет определить, относится ли

Выражение A is C позволяет определить, относится ли объект A к

объект A к классу C или к одному из

его потомков. Если относится, то операция is возвращает true, в противном случае - false.
Например, оператор:
  if Sender is TButton then ...;
 будет реагировать только на объекты класса TButton или потомков этого класса.

Слайд 91 Абстрактные методы и классы.

Абстрактные методы и классы.

Слайд 92 Абстрактные классы
При создании иерархии объектов для исключения повторяющегося

Абстрактные классыПри создании иерархии объектов для исключения повторяющегося кода часто бывает

кода часто бывает логично выделить их общие свойства в

один родительский класс.
При этом может оказаться, что создавать объекты такого класса не имеет смысла, потому что никакие реальные объекты им не соответствуют.
Такие классы называются абстрактными.

Слайд 93 Абстрактные классы
Абстрактные классы служат только для порождения потомков
В

Абстрактные классыАбстрактные классы служат только для порождения потомковВ них задается набор

них задается набор методов, которые каждый из потомков будет

реализовывать по-своему.
Абстрактные методы предназначены для представления общих понятий, которые предполагается конкретизировать в производных классах

Слайд 94 Абстрактные классы
Абстрактные классы задают интерфейс для всей иерархии

При

Абстрактные классыАбстрактные классы задают интерфейс для всей иерархииПри этом методам класса

этом методам класса может не соответствовать никаких конкретных действий



Слайд 95 Абстрактные методы объявляются с директивой abstract



type
TParent =

Абстрактные методы объявляются с директивой abstracttype TParent = class procedure WriteFields;

class
procedure WriteFields; virtual; abstract;
end;
TChild1 = class(TParent)

FName: string;
procedure WriteFields; override;
end;
TChild2 = class(TParent)
FAge: byte;
procedure WriteFields; override;
end;


Слайд 96 Абстрактные методы
Абстрактные методы реализуются только в потомках

Абстрактные методы

Абстрактные методыАбстрактные методы реализуются только в потомкахАбстрактные методы должны обязательно перекрываться в потомках

должны обязательно перекрываться в потомках



Слайд 97 //Реализация
procedure TParent.WriteFields;
begin
Write(‘No fields’);
end;

//Реализация procedure TParent.WriteFields; begin Write(‘No fields’); end; procedure TChild1.WriteFields; begin Write(FName);

procedure TChild1.WriteFields;
begin
Write(FName);
end;

procedure TChild2.WriteFields;
begin

Write(FName);
Write(Fage);
end;

Ошибка. WriteFields - абстрактный

Ошибка. В классе TChild2 нет поля FName


Слайд 98 Методы класса.

Методы класса.

Слайд 99 Методы класса
Некоторые методы могут вызываться без создания и

Методы классаНекоторые методы могут вызываться без создания и инициации объекта.Такие методы

инициации объекта.
Такие методы называются методами класса
Они объявляются с помощью

зарезервированного слова class

Type
TMyClass = class (TObject)
Class Function GetClassName: String;
End;


Слайд 100 Методы класса
Доступ к этим методам осуществляется через имя

Методы классаДоступ к этим методам осуществляется через имя класса, а не

класса, а не имя объекта!
Type
TMyClass = class (tObject)

Class Function GetClassName: String;
End;
 Var
S: String;
Begin
S := TMyClass.GetClassName;
. . . . . .
End;

Слайд 101 Методы класса
Методы класса не должны обращаться к полям,

Методы классаМетоды класса не должны обращаться к полям, т.к. в общем

т.к. в общем случае вызываются без создания объекта, а

следовательно, в момент вызова полей просто не существует.
Обычно они возвращают служебную информацию о классе – имя класса, имя его родительского класса, адрес метода и т.п.

Слайд 102 Одноименные методы

Одноименные методы

Слайд 103 Одноименные методы
Часто бывает, что методы, реализующие один и

Одноименные методыЧасто бывает, что методы, реализующие один и тот же алгоритм

тот же алгоритм не должны обращаться к полям, т.к.

в общем случае вызываются без создания объекта, а следовательно, в момент вызова полей просто не существует.
Обычно они возвращают служебную информацию о классе – имя класса, имя его родительского класса, адрес метода и т.п.

Слайд 104 Одноименные методы
В Delphi в рамках одного класса можно

Одноименные методыВ Delphi в рамках одного класса можно иметь несколько одноименных

иметь несколько одноименных методов.
Рассмотренный ранее механизм перекрытия родительского метода

одноименным методом потомка приводит к тому, что потомок «не видит» перекрытый родительский метод и может обращаться к нему лишь с помощью зарезервированного слова Inherited.

Слайд 105 Одноименные методы
Использование нескольких методов с одним и тем

Одноименные методыИспользование нескольких методов с одним и тем же именем, но

же именем, но с различными наборами параметров называется перегрузкой

методов.
Одноименные методы будут доступны если объявить их с директивой overload (перезагрузить)
В результате станут видны одноименные методы как родителя, так и потомка.

Слайд 106 Одноименные методы
Важно:
Чтобы одноименные методы можно было отличить друг

Одноименные методыВажно:Чтобы одноименные методы можно было отличить друг от друга, каждый

от друга, каждый из них должен иметь уникальный набор

параметров.

В ходе выполнения программы при обращении к одному из одноименных методов программа проверяет тип и количество фактических параметров обращения и выбирает нужный метод.

Слайд 107 Одноименные методы
При обнаружении одноименного метода компилятор Delphi предупреждает

Одноименные методыПри обнаружении одноименного метода компилятор Delphi предупреждает о том, что

о том, что у класса уже есть аналогичный метод

с другими параметрами.
Для подавления сообщений объявление одноименного метода можно сопровождать зарезервированным словом reintroduce (вновь ввести).

Слайд 108 Type
TForm1 = class (TForm)
Button1 : TButton;
Button2 :

Type TForm1 = class (TForm)	Button1 : TButton;	Button2 : TButton;	Button3 : TButton;	Button4

TButton;
Button3 : TButton;
Button4 : TButton;

Procedure Button1Click(Sender:TObject);
Procedure Button2Click(Sender:TObject);
Procedure Button3Click(Sender:TObject);
Procedure Button4Click(Sender:TObject);
Private
procedure Close(S: String); reintroduce; overload;
procedure Close(I: Integer); reintroduce; overload;
procedure Close(I, J: Integer); reintroduce; overload;
End; 

Слайд 109 implementation
 
Procedure TForm1.Close(S: String);
Begin
Caption := S;
End;
 
Procedure TForm1.Close(I:

implementation Procedure TForm1.Close(S: String);	Begin	 Caption := S;	End; Procedure TForm1.Close(I: Integer);	Begin	 Caption := IntToStr(I);	End; Procedure

Integer);
Begin
Caption := IntToStr(I);
End;
 
Procedure TForm1.Close(I, J: Integer);
Begin

Caption := IntToStr(i * j);
End;

  • Имя файла: vvedenie-v-delphi.pptx
  • Количество просмотров: 106
  • Количество скачиваний: 0