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

相关文章

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

Java 继承和多态的作用及好处

《Java继承和多态的作用及好处》文章讲解Java继承与多态的概念、语法及应用,继承通过extends复用父类成员,减少冗余;多态实现方法重写与向上转型,提升灵活性与代码复用性,动态绑定降低圈复杂度... 目录1. 继承1.1 什么是继承1.2 继承的作用和好处1.3 继承的语法1.4 子类访问父类里面的成

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复