![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() |
hoRUS |
![]()
Сообщение
#1
|
Студент ![]() Группа: Участник Сообщений: 30 Регистрация: 10.7.2008 Из: Москва Пользователь №: 231 Спасибо сказали: 5 раз(а) Репутация: ![]() ![]() ![]() |
Никак не могу найти толкового ответа, что же лучше, "правильнее" (с архитектурной точки зрения), использовать для даункастинга в Qt-проектах - dynamic_cast или qobject_cast? В проекте, допустим, нет ограничений на использование RTTI, кастовать через границы динамических библиотек, допустим, не требуется, интересует прежде всего производительность на большинстве платформ (прежде всего Linux x86 + GCC) и архитектурная обоснованность (хотелось бы послушать опытных) того или иного подхода. Кастуются наследники QObject с макросом Q_OBJECT и интерфейсы, обработанные макросом Q_DECLARE_INTERFACE().
Или лучше вообще избегать динамического даункастинга и обходиться виртуальными функциями? Например, в базовом классе определять enum с константами, присвоенными разным типам наследников и виртуальной ф-цией возвращать тип и, осонвываясь на этом типе, статик-кастом делать приведение? Это сильное издевательство над ООП? dynamic_cast "внутри" работает не похожим способом? Слышал, что он может быть реализован не на vtable, а на сравнении строк strcmp() - это звучит страшно. |
|
|
![]() |
Litkevich Yuriy |
![]()
Сообщение
#2
|
![]() разработчик РЭА ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: ![]() ![]() ![]() |
|
|
|
![]() ![]() ![]() |
![]() |
Текстовая версия | Сейчас: 26.2.2025, 21:25 |