Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.07.11;
Скачать: CL | DM;

Вниз

Реализация TDataLink у Борланда: непонятки   Найти похожие ветки 

 
Ega23 ©   (2005-06-10 13:42) [0]

Вот есть у TDataLink следующие методы:

 protected
   procedure ActiveChanged; virtual;
   procedure UpdateData; virtual;


А зачем они объявлены как virtual, а не как virtual; abstract;?
Ведь их реализация у TDataLink пустая?


 
-=XP=- ©   (2005-06-10 13:43) [1]

Чтобы не было Abstract Error.


 
TUser ©   (2005-06-10 13:46) [2]

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

Кроме того, в Борланде много программистов, и стиль у каждого свой.


 
TUser ©   (2005-06-10 13:46) [3]

> Чтобы не было Abstract Error.

Не будет, если не вызывать эти методы.


 
default ©   (2005-06-10 13:48) [4]

[1]
смысл в том, что, видимо, класс TDataLink полноценно может использоваться, в то время как в потомках могут специфицироваться указанные методы
если бы этот класс бы лишь каркасом, тогда бы стоило эти методы сделать абстрактными, показав тем самым что без их спецификации класс юзать незачем


 
default ©   (2005-06-10 13:48) [5]

TUser ©   (10.06.05 13:46) [2]
одиинаково мыслим:)


 
Ega23 ©   (2005-06-10 13:49) [6]

Но вот сколько я ни смотрел VCL, я понял, что реально TDataLink не используется напрямую. Используются его наследники TGridDataLink, TFieldDataLink etc.


 
default ©   (2005-06-10 13:52) [7]

Ega23 ©   (10.06.05 13:49) [6]
вопрос не в том используется или инет
а в возможности использования


 
Ega23 ©   (2005-06-10 14:01) [8]

Всё равно не понимаю. Даже если просто возможность использования, то эти методы придётся не переопределять, а адреса им другие подставлять....
Нет, не понимаю зачем...


 
default ©   (2005-06-10 14:09) [9]

Ega23 ©   (10.06.05 14:01) [8]
" Даже если просто возможность использования, то эти методы придётся не переопределять, а адреса им другие подставлять...."
не понял:(

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


 
Ega23 ©   (2005-06-10 14:14) [10]

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

ТАК ОНИ В БАЗОВОМ КЛАССЕ ПУСТЫЕ!!!

Вот:

procedure TDataLink.UpdateData;
begin
end;


Я понимаю, если бы у базового класса был какой-то обработчик, его через inherited можно было-бы вызвать. А если он пуст, то нафига его вызывать???? ИМХО, только в том случае, если "генофонд" портить...

не понял:(

ну для виртуального метода в потомке можно override сделать, а можно просто подменить метод (UpdateData:=MyUpdateData;) без потомков.


 
default ©   (2005-06-10 14:26) [11]

Ega23 ©   (10.06.05 14:14) [10]
есть идёт использование только этих методов тогда действительно смысла нет
то есть, для конкретики, может есть смысл вызывать полиморфно метод базового класс который что-то полезное делает и кроме того вызывает эти пустые методы(дабы допустить использование этого метода(который может что-то полезное делать) и без определения этих пустых методов)


 
Ega23 ©   (2005-06-10 14:33) [12]

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


а-а-а-а... Вон оно как... Т.е. сам TDataLink в каком-то другом своём методе может дёргать эти пустые методы, предполагая, что их реализация имеется у потомков?


 
TUser ©   (2005-06-10 14:37) [13]

> Ega23 ©   (10.06.05 14:33) [12]

Это во-первых.
А еще есть Warnings - если написать TStrings.Creae, то мы получим предупреждение, что создаваемый объект содержит абстрактный метод, а если написать TDataLink.Create - то не получим. В Борланде решили, что кому-то может пригодиться использовать объект класса TDataLink, а не его наследника.


 
Ega23 ©   (2005-06-10 14:43) [14]

Ну тогда понятно...


 
default ©   (2005-06-10 14:47) [15]

Ega23 ©   (10.06.05 14:33) [12]
да
точнее может быть какой-то метод который в ходе своего выполения обращается к методам ActiveChanged, UpdateData
НО, что самое главное - это метод может что-то делать полезное и без "наполнения" этих методов
если мы бы их абстрактыми сделали, то получили бы abstract error при вызове этого метода, тем самым потрели бы возможность его использвания


 
Anatoly Podgoretsky ©   (2005-06-10 14:54) [16]

Ega23 ©   (10.06.05 14:33) [12]
Именно так, поскольку будут дергать и другие абстрактные методы. Это типичный прием.


 
evvcom ©   (2005-06-10 14:56) [17]

Посмотри у TQuery:
FDataLink := TQueryDataLink.Create(Self);
в TQueryDataLink ActiveChanged перекрыт, а UpdateData нет. А UpdateData в очень многих местах в TDataLink вызывается. Получается, что в этих классах можно было бы и обойтись без UpdateData. Но где-то (в каких-то других потомках от TDataLink)можно было бы и без ActiveChanged обойтись, а без UpdateData нет.
Эти методы добавляют в базовые классы гибкость без принуждения реализовывать их в потомках в случае ненадобности.


 
Ega23 ©   (2005-06-10 15:12) [18]

2 evvcom ©   (10.06.05 14:56) [17]

Я уже понял, спасибо.



Страницы: 1 вся ветка

Текущий архив: 2005.07.11;
Скачать: CL | DM;

Наверх




Память: 0.49 MB
Время: 0.038 c
11-1101836172
Nils
2004-11-30 20:36
2005.07.11
Нужен компонент по типу как список файлов в WinRARe


1-1119432901
DelphiN!
2005-06-22 13:35
2005.07.11
Вызов ф-ии в отдельном потоке, с получением результата


1-1119452828
Суслик
2005-06-22 19:07
2005.07.11
Фокус при выводе диалоговых окон в MDI приложениях


1-1118525029
Николай,гер
2005-06-12 01:23
2005.07.11
поиск слова в тексте и удаление его !!!


14-1118491946
Кирилл
2005-06-11 16:12
2005.07.11
Инсталятор





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский