Навигация
Главная
Поиск
Форум
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
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 12
На сайте нет зарегистрированных пользователей

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

Метод конечных разностей для интерполяции/экстраполяции на Delphi
Моделирование процесса передачи данных по магистрали с основным и резерв...
База данных студентов на Turbo Pascal (Списки) + Пояснительная записка

Поля и методы при наследовании
Как уже отмечалось, класс-наследник получает в наследство все поля базового класса (хотя, если они были приватные, доступа к ним он не имеет). В этом легко убедиться, выведя на экран размеры базового класса TCurrency и класса-наследника Roubles:
cout << sizeof(TCurrency) << endl; cout << sizeof(Roubles) << endl;



Так как мы не добавляли полей в производный класс, то на экран в обоих случаях будет выдано одно и то же число — размер поля Summa. В классе Point3D мы добавили поле z, поэтому размер класса увеличился по сравнению с классом Point2D на размер типа double.
Добавляемые поля в наследнике могут совпадать и по имени, и по типу с полями базового класса. Конечно, специально так делать не следует, но это не запрещено стандартом, поэтому нужно разобраться, как обращаться к полям с одинаковыми именами. Модифицируем наш пример из листинга 8.5, добавив в базовый и производный классы поля с одинаковыми типами и именами (листинг 8.6).

Листинг 8.6. Одинаковые поля в базовом и производном классах
class Base { protected: int x; public:
Base(int x):x(x) { cout << "Base" << endl; } ~Base() { cout << "-Base" << endl; }
};
class Derived: public Base { int x; public:
Derived(int x):x(x),Base(x+1) { cout << "Derived" << endl; } ~Derived() { cout << "-Derived" << endl; } int f() { return (Base::x+x); }
};



В базовом классе мы объявили поле в защищенной секции, чтобы класс-наследник мог непосредственно к нему обращаться. Естественно, в производном классе новое поле скрывает поле базового класса, поэтому для доступа к полю базового класса необходимо использовать квалификатор класса, что и показано в методе f ().
Класс-потомок наследует все поведение базового класса. Это означает, что нет необходимости заново определять операции в классе-наследнике, если их поведение не изменяется по сравнению с поведением в базовом классе. Снова обратимся к классу Roubles, наследнику класса TCurrency, и проверим работу операций, выполнив простую программу, представленную в листинге 8.7.
= 0.0 = 1.01 = 5.03
Листинг 8.7. Проверка работы операций в классе-наследнике
int main()
{ Roubles d; cout << d << endl; // d
++d; d++; cout << d << endl; // d
d+=4.02; cout << d << endl; // d
return 0;
}



В примере мы не стали проверять все методы, определенные в базовом классе, — и так понятно, что все они правильно работают с объектами класса-наследника, хотя определены в базовом классе.
Естественно, в классе-наследнике допустимо определять новые методы, что можно видеть в листинге 8.4: в производном классе Point30 определен метод getz(). Во вновь определяемых методах разрешается вызывать любые доступные методы базового класса. Если в классе-наследнике имя метода совпадает с именем метода базового класса, то метод производного класса скрывает все методы базового класса с таким именем. При этом прототипы могут не совпадать.
Таким образом, чтобы в методе-наследнике вызвать одноименный метод родительского класса, нужно задавать его с квалификатором класса. Добавим в класс Point 2D метод PrintQ для вывода на экран координат точки:
void PrintO const
{ cout << x <<','<< у: }



В производном классе Poi nt3D определим метод с тем же именем. Чтобы вывести координаты х и у, вызовем одноименный метод базового класса:
void PrintO const
{ Base::Print(): cout <<','<< z; }



Обновить программисту свое рабочее место помогут красивые http://8themes.ru тут.
Аналогично можно выполнять метод базового класса для объекта-наследника, например:
Poinr3D Т:
Т.PrintO: // вызов "родного" трехмерного метода
Т.Base::PrintO: // вызов "родительского" двухмерного метода


Опубликовал Kest November 19 2013 22:04:36 · 0 Комментариев · 4667 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Prolog Interprete...
DragMe [Исходник ...
Простой текстовый...
MiniChat
Использование Lis...
Длинный заголовок...
Программирование ...
С/C++ Программиро...
Borland Delphi 6....
Заставка. Изображ...
FileFind
Работа с базами д...
MpegPlay
Ics
Flash MP3 Player ...
KOL & MCK v1.69
Экранная лупа
Панель Наша Кнопка
Медиа комбайн
PBFoldder

Топ загрузок
Приложение Клие... 100800
Delphi 7 Enterp... 98064
Converter AMR<-... 20302
GPSS World Stud... 17068
Borland C++Buil... 14261
Borland Delphi ... 10388
Turbo Pascal fo... 7398
Калькулятор [Ис... 6093
Visual Studio 2... 5241
Microsoft SQL S... 3676
Случайные статьи
в кадре использует...
Целые числа: удиви...
Файл main.срр — пр...
Планируя агенты во...
Общая информация о...
Разметка текста шр...
Кодовые точки и ко...
Часто критически в...
JET casino
Глава 24. Что д...
Общие подходы к пр...
Где мы находимся?
Ещё о защите e-mai...
Таблица 7.2. Прави...
Команда giTeximageiD
Причины хранения и...
Особенности органи...
Каталог алгоритмов
Тема адресации и с...
Средства обработки...
1.4.4. Параметры к...
Line too long
Добавить объект P...
административных г...
Разработка микропр...
Статистика



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


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