Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 62838
Создание отчето... 62829
ТЕХНОЛОГИИ ДОСТ... 59364
Пример работы с... 58090
Имитационное мо... 54759
Реклама
Сейчас на сайте
Гостей: 11
На сайте нет зарегистрированных пользователей

Пользователей: 13,074
новичок: gerasim971
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных студентов на Delphi (файл записей) + Блок схемы
Моделирование работы аэропорта на GPSS + Пояснительная записка
Принадлежит ли точка пересечению двух окружностей на Turbo Pascal + Отче...

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
RTTI
В главе 9 при обсуждении виртуальных методов мы уже упоминали механизм RTTI, с помощью которого можно определить тип объекта во время выполнения; имея только указатель на него. Механизм динамической идентификации типа состоит из трех составляющих:
• оператора динамического преобразования типа dynamic_cast<> (см. п. п. 5.2.7
в [1]);
• оператора идентификации точного типа объекта typeidO (см. п. п. 5.2.8 в [1]);
• класса type_info (см. п. п. 18.5.1 в [1]);
Оператор dynamic__cast<> допускается применять к указателям только на полиморфные классы (содержащие хотя бы одну виртуальную функцию). Вообще-то любой класс легко сделать полиморфным, определив для него виртуальный деструктор. Оператор имеет следующий формат:
dynamic_cast<TMn *>(указатель)
Результатом является преобразованный указатель. Если преобразование указателя к нужному типу выполнить не удается, оператор возвращает нулевой указатель. Следовательно, результат преобразования нужно всегда проверять.
Преобразования допускаются только между «родственниками», то есть классами, входящими в одну иерархию наследования (тип указателя в круглых скобках должен быть родственным типу в угловых скобках). Преобразование может быть:
• повышающим — от производного класса к базовому;
• понижающим — от базового класса к производному;
• перекрестным — от одного производного класса к другому.
Как мы знаем, повышающее преобразование выполняется обычно по умолчанию посредством подстановки (см. главу 8). Тем не менее можно его выполнить и явно. Понижающее и перекрестное преобразования выполняются только с помощью оператора dynamic_cast<>.
Оператор dynamic_cast<> можно применять и к ссылкам. Формат оператора в этом случае такой:
dynamic_cast<THn &>(ссылка)
Все условия относительно «родственности» полиморфных классов должны выполняться и в этом случае, однако обработка аварийного случая происходит по-другому. Так как нулевых ссылок не бывает, при невозможности преобразования ссылки генерируется исключение bad_cast (см. п. п. 18.5.2 в [1]).
Если оператор dynamic_cast<> выполняет преобразование одного типа в другой, то оператор typeidO позволяет выяснить фактический тип класса. Для использования этого оператора необходимо включить в программу заголовок
#include <typeinfo>



В этом классе представлен класс type_info, который возвращается в качестве результата оператором typeidO. В стандарте (см. п. п. 18.5.1 в [1]) класс type_ i nf о определен так, как показано в листинге 10.6.

Листинг 10.6. Класс typejnfo
class type_info { public:
virtual ?type_info();
bool operator==(const type_info& rhs) const; bool operator!=(const type_info& rhs) const; bool before(const type_info& rhs) const; const char* name() const; private:
type_info(const type_info& rhs); type_info& operator=(const type_info& rhs);
};



Как видите, объекты типа type_info невозможно ни создать, ни скопировать — конструкторы и операция присваивания закрыты. Объекты типа type__info можно сравнивать между собой — и это основные операции, которые используются совместно с оператором typeidO; можно получить имя типа с помощью метода name О. Как написано в [2], метод before () «позволяет сортировать информацию о типе type_info. Нет никакой связи между отношениями упорядочения, определяемыми beforeO, и отношениями наследования».
Оператор typeidO имеет две синтаксически одинаковые формы — разница заключается в аргументе:
typei d(выражение) typeid(MMfl_Tnna)



В качестве выражений наиболее часто применяются указатели. Таким образом, оператор typei d () позволяет определить точный тип объекта, на который указывает указатель. Если указатель нулевой, то возбуждается исключение bad_typeid (см. п. п. 18.5.3 в [1]). В качестве имени типа используются имена классов. Однако в отличие от dynamic__cast<>, оператор typeidO можно применять к встроенным типам. Полезного в этом мало, но ошибки не вызывает.
Так как оператор typeidO возвращает объект типа type_info, то можно сравнивать эти объекты и вызывать методы класса type_i nf о. В справочной системе С++ Borland 6 есть пример, иллюстрирующий простейший случай использования оператора typeidO. Мы его модифицируем и дополним (листинг 10.7).

Листинг 10.7. Простое использование оператора typeidO
class D{ }; // базовый класс
class В: D { }; // наследник
int main() { char С: float,X:
if (typeid(C) == typeid(X)) // сравнили типы
cout << "С и X - одного типа!" << endl;
else cout << "С и X - разного типа! " << endl;
cout << typeid(int).name(); // выводит int
cout << typeid(double).name(); // выводит double
cout << boolapha <<
(typeid(int).before(typeid(double))?true:false)
<< endl; // выводит false
cout << typeid(D).name(); // выводит D
cout << typeid(B).name(); // выводит В
cout << boolapha <<
(typeid(D).before(typeid(B))?true:false)
<< endl; // выводит false
int iobj;
cout << typeid(iobj).name(); // выводит int
out << typeid(8.16).name(); // выводит double
}



Опубликовал Kest December 03 2013 05:13:37 · 0 Комментариев · 2752 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
AdBlaster v2.5 - ...
Delphix Sample [И...
JanComp
Паскаль и Дельфи....
Matrix2D
Программирование ...
Calendar
Система баннеро...
Файловый менеджер
С# для профессион...
FilesInfo
Импорт новостей ...
EditNew
Delphi 2005 Учимс...
Динамические за...
oTextrackBar
Bitmap [для кнопок]
Технология .Net в VB
Animated Menus
PDA версия сайта

Топ загрузок
Приложение Клие... 100422
Delphi 7 Enterp... 84987
Converter AMR<-... 20062
GPSS World Stud... 11987
Borland C++Buil... 11408
Borland Delphi ... 8388
Turbo Pascal fo... 7008
Visual Studio 2... 4985
Калькулятор [Ис... 4631
FreeSMS v1.3.1 3530
Случайные статьи
LINK (ВВЕСТИ В СПИ...
Насколько она слож...
Инструменты для по...
Компиляция модулей
Передача коммутато...
Хотите поэкспериме...
Задачи, стоящие пе...
АЛФАВИТ ЯЗЫКА
Audit System Event...
Распутывание вино...
Процедуры и функци...
Некоторые фрагмент...
Анализ зависимости...
Глава 13
Чистые виртуальные...
Модуль Legacy
Природа нулевой эн...
Страница для указа...
Что такое SEO, SEA...
Ввод и вывод широк...
Умеете ли вы делат...
Особенности примен...
Протокол LACP IEEE...
ПФЭК
кол источ- источ- ...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?