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

Вниз

Использование типа object   Найти похожие ветки 

 
goobit   (2003-05-22 18:04) [0]

Собственно интересно ваше мнение по поводу использования в проектах "устаревшего" типа object. Хотя в документации к любой версии Delphi информация по ним практически отсутствует, они обладают рядом существенных приемуществ:
- могут не содержать VMT, что позволяет делать оболочки для обычных record"ов (например для TRect)
- Если нет VMT, то объект можно создать как переменную в стеке и не заботиться о конструкторе и деструкторе, что может существенно повысить скорость.

Собственно почему ребята из Borland так активно не советуют его использовать при некоторых явных приемуществах в определенных задачах?


 
DiamondShark ©   (2003-05-22 19:29) [1]


> - могут не содержать VMT, что позволяет делать оболочки
> для обычных record"ов (например для TRect)

Не понял, "оболочка" -- это как? Рекорд со статическими методами? Чем это лучше рекорда и набора глобальных процедур?


> - Если нет VMT, то объект можно создать как переменную в
> стеке и не заботиться о конструкторе и деструкторе, что
> может существенно повысить скорость.

Повысить по отношению к чему?


> Собственно почему ребята из Borland так активно не советуют
> его использовать при некоторых явных приемуществах в определенных
> задачах?

Собственно, преимуществ (опять же, перед чем?) не наблюдается. Зато наблюдается явная иизбыточность. Так что ребята из Борланд не достаточно активны, могли бы ещё в 1-2 версии это хозяйство выбросить.


 
y-soft ©   (2003-05-22 20:23) [2]

Насчет выбросить это наверное рановато. Зачем отбирать у языка гибкость. Посмотрите, например, как портирована на Delphi работа с GDI+


 
goobit   (2003-05-23 15:26) [3]

Для меня, например, более удобной является запись Rect1.Intersect(Rect2), а не Rect1 := IntersectRect(Rect1, Rect2). Это касается и простых обработчиков пакетов, когда данные пакета содержатся в объекте и их можно просто прочитать из потока (не заботясь о VMT).

На счет стека: нормальным путем экземпляр в стеке создать нельзя (в отличии от C++), а выделение памяти в стеке ВСЕГДА будет быстрее выделенея памяти в куче. Если создание/удаление происходит довольно часто, то даже десятки микросекуд становятся важными. Конечно, такие объекты не могут поддерживать полиморфизм (так как нельзя создать виртуальных методов), но для простых классов это не обязательно.

На мой взгляд именно выигрыш в читабельности кода не в ущерб быстродействию.



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
14-26691
_Alex_
2003-05-24 11:01
2003.06.09
Методика рассчета загрязнения атмосферы


7-26803
zolotov
2003-04-05 19:56
2003.06.09
Kernel32.dll в Win2k. Скрытие приложения при нажатии Ctrl+Alt+Del


1-26586
-=GaLaN=-
2003-05-28 15:14
2003.06.09
Приоритет программы


14-26700
corte ™
2003-05-21 10:13
2003.06.09
Как отобразить в мемо поле обект БД процедуру


14-26737
neuro
2003-05-22 17:52
2003.06.09
STL 4 delphi