Учебники

Objective-C Наследование

Одним из наиболее важных понятий в объектно-ориентированном программировании является наследование. Наследование позволяет нам определять класс в терминах другого класса, что облегчает создание и поддержку приложения. Это также дает возможность повторно использовать функциональность кода и быстрое время реализации.

При создании класса, вместо того, чтобы писать совершенно новые члены-данные и функции-члены, программист может указать, что новый класс должен наследовать члены существующего класса. Этот существующий класс называется базовым классом, а новый класс называется производным классом.

Идея наследования реализует отношения. Например, млекопитающее IS-A животное, собака IS-A млекопитающее, следовательно, собака IS-A животное, а также и так далее.

Базовые и производные классы

Objective-C допускает только многоуровневое наследование, т. Е. Он может иметь только один базовый класс, но допускает многоуровневое наследование. Все классы в Objective-C являются производными от суперкласса NSObject .

@interface derived-class: base-class

Рассмотрим базовый класс Person и его производный класс Employee следующим образом:

Live Demo

#import <Foundation/Foundation.h>
 
@interface Person : NSObject {
   NSString *personName;
   NSInteger personAge;
}

- (id)initWithName🙁NSString *)name andAge🙁NSInteger)age;
- (void)print;

@end

@implementation Person

- (id)initWithName🙁NSString *)name andAge🙁NSInteger)age {
   personName = name;
   personAge = age;
   return self;
}

- (void)print {
   NSLog(@"Name: %@", personName);
   NSLog(@"Age: %ld", personAge);
}

@end

@interface Employee : Person {
   NSString *employeeEducation;
}

- (id)initWithName🙁NSString *)name andAge🙁NSInteger)age 
  andEducation🙁NSString *)education;
- (void)print;
@end

@implementation Employee

- (id)initWithName🙁NSString *)name andAge🙁NSInteger)age 
   andEducation: (NSString *)education {
      personName = name;
      personAge = age;
      employeeEducation = education;
      return self;
   }

- (void)print {
   NSLog(@"Name: %@", personName);
   NSLog(@"Age: %ld", personAge);
   NSLog(@"Education: %@", employeeEducation);
}

@end

int main(int argc, const char * argv[]) {
   NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];        
   NSLog(@"Base class Person Object");
   Person *person = [[Person alloc]initWithName:@"Raj" andAge:5];
   [person print];
   NSLog(@"Inherited Class Employee Object");
   Employee *employee = [[Employee alloc]initWithName:@"Raj" 
   andAge:5 andEducation:@"MBA"];
   [employee print];        
   [pool drain];
   return 0;
}

Когда приведенный выше код компилируется и выполняется, он дает следующий результат —

2013-09-22 21:20:09.842 Inheritance[349:303] Base class Person Object
2013-09-22 21:20:09.844 Inheritance[349:303] Name: Raj
2013-09-22 21:20:09.844 Inheritance[349:303] Age: 5
2013-09-22 21:20:09.845 Inheritance[349:303] Inherited Class Employee Object
2013-09-22 21:20:09.845 Inheritance[349:303] Name: Raj
2013-09-22 21:20:09.846 Inheritance[349:303] Age: 5
2013-09-22 21:20:09.846 Inheritance[349:303] Education: MBA

Контроль доступа и наследование

Производный класс может обращаться ко всем закрытым членам своего базового класса, если он определен в классе интерфейса, но он не может получить доступ к закрытым членам, которые определены в файле реализации.

Мы можем суммировать различные типы доступа в зависимости от того, кто может получить к ним доступ следующим образом —

Производный класс наследует все методы и переменные базового класса со следующими исключениями:

Переменные, объявленные в файле реализации с помощью расширений, недоступны.

Методы, объявленные в файле реализации с помощью расширений, недоступны.

Если унаследованный класс реализует метод в базовом классе, то выполняется метод в производном классе.