day3: 继承、初始化方法、便利构造器

2024-04-08 05:08

本文主要是介绍day3: 继承、初始化方法、便利构造器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OC第三讲  继承、初始化方法、便利构造器

继承 是面向对象的主要特征
 
 1、OC的根类是NSObject
 2、继承是单向继承,不能双向继承,只有子类继承父类,不能父类继承子类
 3、OC里所有的类只能有一个父类,不可能出现一个类有两个或多个父类,叫单根继承(C++可以继承多个类)
 4、子类继承父类,继承父类的所有成员变量和方法;
 5、子类不能声明跟父类同名的成员变量。
 6、成员变量的内存分配,子类使用父类的方法,成员变量存储是和父类没关系的
 7、子类执行方法的过程:在OC中执行方法的顺序,(1)、在本类中找方法的实现,如果存在就直接执行;(2)、如果不存在就继续在父类查找,如果存在就执行父类里的实现,如果不存在就继续往父类的父类进行查找,直到NSObject为止。(3)、如果NSObject中还没找到就直接崩溃。
 8、super指令 是一个操作指令,只是一个操作符 不是对象 用的是非常非常多
    super的作用是帮助子类去执行父类的方法,不是父类在执行他自己的方法;
 
 方法的调用:
 重写父类声明的方法也叫接口继承
 
 初始化方法:
 9、功能:在创建对象的时候就给成员变量赋值(setter方法是在使用的时候赋值)
 10、初始化方法是减号方法
 11、初始化方法的步骤(1)执行父类的实现(2)判断父类是否执行成功,如果成功给成员变量赋值。如果失败返回NULL
 //完整的重写初始化方法
 -(instancetype)init{
 //1、让子类对象执行父类的方法实现,并将实现结果继承过来
 self = [super init];  //这个self谁调用就是谁的
 //2、判断父类的实现是否执行成功,如果执行成功才给成员变量赋值,如果失败直接返回。
 if (self) {
 _name=@"张三";
 }
 return self;
 }
 
 self:哪个对象调用self就表示谁。
 
 便利构造器:
 12、将对象的创建过程封装在一个类方法里(+方法),构造一个对象并且给他的成员变量赋值。作用:分配内存和初始化方法在一个地方实现
    便利构造器封装了对象的创建过程,进一步简化了对象的创建步骤
    便利构造器是一个加号方法,也就是说是一个“类方法”;
    命名规则:前缀是类名,参数可以有0到多个


Person.h

#import <Foundation/Foundation.h>//NSObject 是OC里面的根类  所有类都继承于它 它没有父类
//在OC中自定义的类,必须得有一个基类,要么直接继承于NSObject,要么间接继承于NSObject;@interface Person : NSObject{NSString *_name;    //名字NSString *_sex;     //性别@privateNSUInteger _age;   //年龄
}
//自定义一个按name初始化的方法(id和instancetype都是泛型)
-(instancetype)initWithName:(NSString *)name;
//自定义给所有成员赋值的方法:
-(instancetype)initWithName:(NSString *)name andSex:(NSString *)sex andAge:(NSUInteger)age;//声明setter
-(void)setName:(NSString *)name;
//声明getter
-(NSString *)name;
-(void)printHello;//先写一个没有返回值的+方法
+(void)printf;
//声明一个便利构造器方法,命名规则:类名做前缀,可以有参数
+(Person *)personWithName:(NSString *)name;@end

Person.m

#import "Person.h"@implementation Person//完整的重写初始化方法
-(instancetype)init{//1、让子类对象执行父类的方法实现,并将实现结果继承过来//self是个指针变量,里面存的地址,失败的话返回NULL//谁在调用init这个方法,init就是谁的self = [super init];//2、判断父类的实现是否执行成功,如果执行成功才给成员变量赋值,如果失败直接返回。if (self) {_name=@"张三";}return self;
}
//实现自定义初始化方法
-(instancetype)initWithName:(NSString *)name{self = [super init];if (self) {_name=name;}return self;
}
//自定义给所有成员赋值的方法:
-(instancetype)initWithName:(NSString *)name andSex:(NSString *)sex andAge:(NSUInteger)age{self=[super init];if (self) {_name=name;_sex=sex;_age=age;}return self;
}-(void)printHello{NSLog(@"Hello World");
}
//声明setter
-(void)setName:(NSString *)name{_name=name;
}
//声明getter
-(NSString *)name{return _name;
}//+类方法实现的时候中不能有实例变量
//类方法只能用类名来进行调用
+(void)printf{//类方法中不能使用成员变量//NSLog(@"%@",_name);NSLog(@"Hello OC");
}//便利构造器实现的是将创建对象的过程进行封装,将对象的内存管理放到一个方法中,方便我们在创建对象的时候进行调用,
//便利构造器代码没有省,但是方便了调用
+(Person *)personWithName:(NSString *)name{Person *p=[[Person alloc]initWithName:name];return p;
}@end

Student.h

#import "Person.h"
/*在.h 文件里面@class ** 这个类,我们还需要在.m文件里重新引入一遍,这样,我们就可以在.m文件里使用了*/@interface Student : Person{
//    NSString *_name; //子类不能声明跟父类同名的成员变量//在子类中声明的实例变量或者方法是子类特有的;NSString *_number;
}
-(void)setAge:(NSUInteger)age;
-(NSUInteger)age;@end

Student.m

#import "Student.h"@implementation Student-(instancetype)init{self=[super init];if (self) {;}return self;
}//重写父类声明的方法也叫接口继承
-(void)printHello{//super 是一个操作指令,只是一个操作符 不是对象 用的是非常非常多//super的作用是帮助子类去执行父类的方法,不是父类在执行他自己的方法;[super printHello];NSLog(@"我是student的 Hello World");
}-(void)setAge:(NSUInteger)age{//私有成员变量,子类只能继承不能使用_age=age;  //因_age为私有变量,所以这里会报错
}-(NSUInteger)age;{    return _age;  //因_age为私有变量,所以这里会报错
}@end

main.m

#import <Foundation/Foundation.h>
#import "Person.h"
#import "Student.h"int main(int argc, const char * argv[]) {
/*//创建person对象 alloc是一个加号方法,是NSObject中的方法//栈区存的地址都是函数或者方法来分配的Person *p=[[Person alloc]init];//子类里面声明和定义的方法,父类不能进行调用,只有子类以及子类的子类来调用[p printHello];//给name赋值[p setName:@"ABC"];//创建student对象Student *student=[[Student alloc]init];//在OC中执行方法的顺序,1、在本类中找方法的实现,如果存在就直接执行;2、如果不存在就继续在父类查找,如果存在就执行父类里的实现,如果不存在就继续往父类的父类进行查找,知道NSObject为止。3、如果NSObject中还没找到就直接崩溃。
//    student=[NSString alloc];[student printHello];[student setName:@"zhangsan"];    NSLog(@"p.name=%@",[p name]);NSLog(@"student.name=%@",[student name]);
*/Person *p1=[[Person alloc]init];Person *p2=[[Person alloc]init];Person *p3=[[Person alloc]initWithName:@"123"];Person *p4=[[Person alloc]initWithName:@"ABC"];Student *s=[[Student alloc]init];//类方法只能用类名来调用[Student printf];//便利构造器的作用,只是方便了调用Person *per=[Person personWithName:@"lisi"];return 0;
}


这篇关于day3: 继承、初始化方法、便利构造器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/884649

相关文章

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at