继承: 1.单向继承,一个类只能有一个父类,一个父类可以有多个子类. 2.单向继承,基类(根类)是OSObject 3.子类可以继承父类的属性和方法 当父类的方法不满足子类的需求时,子类可以重写父类的方法,重写父类的方法,在子类中不需要再次声明. 1.完全重写 2.部分重写   使用super 建立继承关系之后,子类可以继承父类的: 1.实例变量,@public@protected修饰情况之下 2.公开的方法 一个方法如果在.h中声明了,那么这个方法就是公开的方法,如果没有声明,则是私有的. O…
//版本1 //- (id)init //{ //    work = @"工作"; //    return self; //} // //    //版本2:调用父类的init方法,为父类的实例变量赋初值 //- (id)init //{ //    [super init]; //    work = @"工作"; //    return self; //} // //    //版本3:出于安全考虑,判断父类是否初始化成功,如果父类初始化成功,,在初始子类…
因为利用便利初始化在便利构造器中进行初始化,所以要利用便利初始化的声明及实现部分,可与前篇做比较: 1. 主函数部分: 2. 接口部分: 3. 实现部分: 4. 打印结果: 感兴趣的朋友们可自己与前面的便利初始化和便利构造器做出比较!!!…
1 使用实例setter方法 默认初始化方法 + setName:xxx setAge:xxx 2 使用实例功能类方法,默认初始化方法 + setName:xxx age:xxx3 使用实例初始化方法 initWith开头的方法4 使用构造器 类名+With…以Person  Student两个类为例1 使用实例 setter方法这是最麻烦的方法 @interface Person : NSObject { NSString *_name; NSString *_sex; int _age; }…
import UIKit // 1.一个类中至少有一个指定构造器, 其必须负责初始化类中所有的实例存储属性 // 2.便利构造器属于次要的, 辅助性的构造器 // 3.类中可以不定义便利构造器, 便利构造器必须调用同一个类中的其他构造器完成初始化 // 4.便利构造器的语法格式 convenience init(形参) {} // 5.只有类中才有便利构造器 // 类的构造器链 // Swift对构造器之间的调用链制定了如下3条规则: // 1.子类构造器必须调用直接父类的指定构造器(如果有乳类…
A继承 的作用就是为了,节省代码.     继承 :子类会继承父类 里面所有的内容     思想 :凡是继承过来的实例变量和方法 都是自己的(是从父类遗传过来的)     继承的使用场景 : 当我们多个类有部分相同特征和行为时,我们就可以把相同的部分放到同一个类里面,让下一个类继承即可     对于方法,只要声明了方法的接口,外部都可以访问到     父类 :基类 就是没有父类的类,就是继承的上层(superclass),就叫做基类 祖宗类 OC里面 NSObject.继承的下层是子类(subc…
一.继承 1.面向对象的三大特性:封装,继承,多态.      面向对象提供了继承特性.把公共的方法和实例变量写在父类里,子类只需要写自己独有的实例变量和方法即可.继承既能保证类的完整,又能简化代码.: 表示继承关系. 2.继承的特点:      1)没有父类的类称为根类,OC中的根类是NSObject(祖宗).      2)继承的上层:父类.继承的下层:子类.      3)继承的内容:所有实例变量和方法(不包括私有的).      4)继承是单向的,不能相互继承.      5)继承具有传…
代码: // // main.m #import <Foundation/Foundation.h> #import "Person.h" #import "SingleDog.h" int main(int argc, const char * argv[]) { @autoreleasepool { //改为工程为 非ARC 就是 MRC机制 Person * per = [[Person alloc]initWithName:]; NSString…
1.继承于NSObject class student: NSObject { var name : String? var age : Int = var friend : Int = init(name : String , age : Int , friend : Int) { super.init() self.name = name self.age = age self.friend = friend } init(dict : [String : AnyObject]) { sup…
子类默认不会继承父类的初始化方法,然而,假设某种条件满足的话.父类的初始化方法还是能够继承给子类.在通常情况下,这意味着你不必复写父类的初始化方法.在安全的前提下能够以最低的代价继承父类的初始化方法. 如果子类新增的stored properties 都提供了默认值.那么提供了下面两条规则: 规则1: 假设你的子类未定义不论什么的指定初始化方法(新增便利初始化方法可有可无).那么子类会自己主动继承父类的全部指定初始化方法. 规则2: 假设子类通过规则1.或者通过自己定义实现父类的全部指定初始化方…