Навигация
Главная
Поиск
Форум
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
Содержание сайт... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Invision Power ... 65278
Организация зап... 63934
Модуль Forms 60855
Создание отчето... 60708
ТЕХНОЛОГИИ ДОСТ... 57038
Создание потоко... 56370
Пример работы с... 54266
Имитационное мо... 52476
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

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

Диплом RSA, ЭЦП, сертификаты, шифрование на C#
Принадлежит ли точка пересечению двух окружностей на 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 04:13:37 · 0 Комментариев · 2583 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Введение в станда...
Bitmap [для кнопок]
Архив значков
Программирование ...
HTMLredaktor
Библия хакера 2. ...
Архив программ
Алгоритмы шифрова...
Task Shedule
SynEdit
FileFind
AntiRus
Ранги для форума
RxLIB
MPTools
Запрет гостям ск...
Java 2 - Эффектив...
Самоучитель C++
Платформа програм...
Delphi 6 программ...

Топ загрузок
Приложение Клие... 100376
Delphi 7 Enterp... 83081
Converter AMR<-... 20046
Borland C++Buil... 11177
GPSS World Stud... 10901
Borland Delphi ... 8122
Turbo Pascal fo... 6973
Visual Studio 2... 4963
Калькулятор [Ис... 4357
FreeSMS v1.3.1 3510
Случайные статьи
Какие сайты в Инте...
О казино
Безопастность Dial...
Дублирование строк...
Ordinal type expected
Возникновение взаи...
юридического отдел...
Создание и редакти...
Курс информатики д...
Добыча целевого тр...
Отчет об ошибках: ...
Генератор случайны...
Как повысить тИЦ? ...
В сети Fabrikam ос...
Инфографика для но...
Подключение Micros...
Воспроизведение ви...
10.2. Пример
Определение полимо...
see(X)
Программа cursive ...
Мы воспользуемся п...
Метод базовой точки
Пример программиро...
Операторы описания...
Статистика



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


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