Навигация
Главная
Поиск
Форум
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
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
Имитационное мо... 59416
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

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

Моделирование работы ЭВМ на GPSS + Пояснительная записка
Поиск пути в графе заданном списками инцедентности на Turbo Pascal
База данных склада на Delphi + Схема БД

Реклама



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

ПОДПИСЫВАЙСЯ на канал о программировании
Простое наследование
Простым (или одиночным) называется наследование, при котором производный класс имеет только одного родителя. Мы уже видели пример простого наследования при знакомстве с иерархией исключений. Формально наследование одного класса от другого можно задать следующей конструкций:
class имя_класса_потомка: [модификатор_доступа] имя_базового_класса { тело__класса }



Класс-потомок наследует структуру (все элементы данных) и поведение (все методы) базового класса. Модификатор доступа определяет доступность элементов базового класса в классе-наследнике. Квадратные скобки не являются элементом синтаксиса, а просто показывают, что заключенный в них модификатор может отсутствовать. Этот модификатор мы будем называть модификатором наследования.
При разработке различных классов мы использовали два модификатора доступа к элементам класса: public (общий) и private (приватный). При наследовании используется еще один (см. п. И в [1]) — protected (защищенный). Зачем он понадобился? Рассмотрим пример из реальной жизни. Типичной иерархией наследования является семья, состоящая из нескольких поколений. Все члены семьи имеют общую фамилию и участвуют в общественной жизни (public). С другой стороны, у каждого из членов семьи есть свои личные (private) интимные тайны. Однако члены семьи являются родственниками и участвуют еще и в общей семейной жизни. Семейные тайны хранятся внутри семьи и недоступны обществу, но известны всем членам семьи. Именно «семейная жизнь» объектов потребовала наличия модификатора protected.
Возможны четыре варианта наследования: класс от класса, класс от структуры, структура от структуры и структура от класса. Доступность элементов базового класса из классов-наследников изменяется в зависимости от модификаторов доступа в базовом классе и модификатора наследования. Однако при любых вариантах модификатора наследования приватные элементы базового класса недоступны в наследниках. В табл. 8.1 приведены все варианты доступности элементов базового класса в производном классе при любых вариантах модификатора наследования.
Если в качестве модификатора наследования записано слово public, то такое наследование называется открытым. Соответственно, при использовании модификатора protected мы имеем защищенное наследование, а слово private означает закрытое наследование.
Структуры редко участвуют в иерархии наследования, обычно их используют вполне традиционным способом — для реализации кортежей. Кортеж — это небольшой фиксированный контейнер с элементами разного типа. Общепринятой практикой является, правило — наследовать только от классов. Мы тоже будем стараться этому правилу следовать.
Таблица 8.1. Доступ к элементам базового класса в классе-наследнике
Модификатор доступа Модификатор Доступ в производном классе
в базовом классе наследования struct class
public Отсутствует public private
protected Отсутствует public private
private Отсутствует Нет доступа Нет доступа
public public public public
protected public protected protected
private public Нет доступа Нет доступа
public protected protected protected
protected protected protected protected
private protected Нет доступа Нет доступа
public private private private
protected private private private
private private Нет доступа Нет доступа


Опубликовал Kest November 14 2013 03:36:45 · 0 Комментариев · 3277 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
iChat v.7.0 Final...
Мониторинг сервер...
32 урока по Delphi
Архив программ
MicroGPSS Studen ...
Animation (Пример...
Converter AMR<->W...
Шаблон для новост...
Правила программи...
База игр
Domen Name IP
Интерактивный инт...
Tetris 2002
Создание лабиринт...
Применение жадног...
Ehlib
ShadelLabel
Delphi 2005 Секре...
БД студентов
Основы программир...

Топ загрузок
Приложение Клие... 100512
Delphi 7 Enterp... 90199
Converter AMR<-... 20092
GPSS World Stud... 14943
Borland C++Buil... 12690
Borland Delphi ... 8936
Turbo Pascal fo... 7093
Калькулятор [Ис... 5126
Visual Studio 2... 5018
FreeSMS v1.3.1 3554
Случайные статьи
Технология IEEE 802.1
Процедура RestoreC...
8.7. Задачи
Метод резолюции в ...
2. RADIUS-прокси т...
Работа со списками...
Работа с изображен...
Несжатые данные
Microsoft PowerPoint
Реализация методов
Активизируйте режи...
• Почта со специфи...
Как работают поиск...
3.4. ДОПУСТИМЫЕ СП...
Группа блоков изме...
Определение шаблон...
Манипуляторы
Нужно ли продвигат...
Арифметика с плава...
Подсистема ввода-в...
Работа с нескольки...
Подсказки к некото...
ПРИЛОЖЕНИЕ С. РАЗ...
GSNW, членом групп...
Онлайн казино. Игр...
Статистика



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


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