iOS 继承
一、继承
不恰当的使用继承导致的最大的一个特征就是高耦合。
是否使用继承需要考虑三个点:
- 父类只是给子类提供服务,并不涉及子类的业务逻辑
- 层级关系明显,功能划分清晰,父类和子类各做各的。
- 父类的所有变化,都需要在子类中体现,也就是说此时耦合已经成为需求
万不得已不要用继承,优先考虑组合等方式。
如果只是共享接口,我们可以使用协议;
@protocol ptc <NSObject>
- (void)do;
@end @interface A : NSObject<ptc>
@end @implementation A
- (void)do
{
}
@end @interface B : NSObject<ptc>
@end
@implementation B
- (void)do
{
}
@end
如果希望共用一个方法的部分实现,但希望根据需要执行不同的其他行为,我们可以使用代理或者 AOP;
@protocol ptc <NSObject>
- (void)do;
@end @interface A : NSObject
@property (nonatomic, weak) id<ptc>delegate;
@end @implementation A
- (void)func
{
...
[self.delegate do];
...
}
@end @interface B : NSObject <ptc>
@end @implementation B
- (void)do
{
}
@end
如果是添加方法,我们可以优先使用类别;
如果是为了使用一个类的很多方法,我们可以使用组合来实现。
@interface A : NSObject
- (void)methodA;
@end @interface B : NSObject
-(void)methodB;
@end // 定义 C 以及其需要的 methodA,methodB
@interface C : NSObject
{
A * __a;
B * __b;
}
- (id)initWithA:(A *)a b:(B *)b;
- (void)methodA;
- (void)methodB;
@end @implementation ClassC
- (id)initWithA:(A *)a b:(B *)b
{
__a = [[A alloc] initWithA:a]; // [A copy];
__b = [[B alloc] initWithB:b]; // [B copy];
}
- (void)methodA
{
[__a methodA];
}
- (void)methodB
{
[__b methodB];
}
@end
如果只是出于代码复用的目的而不区分类别和场景,就采用继承是不恰当的。当你发现你的继承超过 2 层的时候,你就要好好考虑是否这个继承的方案了,第三层继承正是滥用的开端。
二、多态
使用场景:
- 父类有部分public的方法是不需要,也不允许子类覆重
- 父类有一些特别的方法是必须要子类去覆重的,在父类的方法其实是个空方法
- 父类有一些方法是可选覆重的,一旦覆重,则以子类为准
- 父类有一些方法即便被覆重,父类原方法还是要执行的
通常带来的问题:
- 容易使得一个对象引入原本不属于它的业务逻辑
- 调用时机或忘记调用
解决方案:
- 面向接口编程(Interface Oriented Programming, IOP)
在决定是否采用多态时,要有一个清晰的角色概念,做好角色细分,不要角色混乱。
三、封装
将相关的一堆函数和一堆对象放在一起,只留给外部程序员操作方式,而不暴露具体执行细节。
带来的问题:
- 制约了并行程度
- 数据部分就是数据部分,执行部分就是执行部分,不同类的东西放在一起是不合适的
四、内容来源
casatwy & 跳出面向对象思想(一) 继承
跳出面向对象思想(二) 多态
跳出面向对象思想(三) 封装
iOS架构师之路:慎用继承
iOS 继承的更多相关文章
- ios 继承UITableViewController,更改tableview样式
// 继承UITableViewController,更改tableview样式 - (instancetype)initWithStyle:(UITableViewStyle)style { ret ...
- ios 继承关系图
- IOS入门之Swift语言(一)
经过不断的努力,小哥也买了台苹果设备,终于可以开始我的IOS之旅了,说来确实令人苦恼,为了学习IOS我这着贫农阶级,省了几个月的零花钱,外加向亲朋好友求救,最终痛下心扉,卖了台MAC pro128G版 ...
- iOS项目开发日常之创建文件(协议、类、分类、扩展)
iOS项目开发过程中,是以不断创建文件的形式进行着的. 创建得比较频繁的文件类型是: 这两个类型中创建的文件有:子类.分类.扩展.协议四种文件,如下: 这四类文件是频繁创建的,我们来看一下各自分 ...
- 字符串流sstream[part1/基本知识]
C++中的输入输出分为三种:基于控制台的I/O,即istream.ostream.iostream:基于文件的I/O,即ifstream.ofstream.fstream:基于字符串的I/O,即ist ...
- C++ stringstream介绍,使用方法与例子
From: http://www.usidcbbs.com/read-htm-tid-1898.html C++引入了ostringstream.istringstream.stringstream这 ...
- stringstream
C++引入了ostringstream.istringstream.stringstream这三个类,要使用他们创建对象就必须包含sstream.h头文件. istringstream类用于执行C++ ...
- C++ 系列:iostream 的用途与局限
转载自http://www.cnblogs.com/Solstice/archive/2011/07/17/2108715.html 本文主要考虑 x86 Linux 平台,不考虑跨平台的可移植性,也 ...
- 30分钟学会Objective-C
注: 本文首发于我的个人博客:https://evilpan.com/2019/04/05/objc-basics/ 请原谅我的标题党.但是如果你有其他语言的学习经验,要学习Objective-C的语 ...
随机推荐
- Grafana使用总结
最近工作需求学习了下grafana,根据创建的几个dashboard简要记录下创建过程. 本次使用了grafana做可视化展示,data source使用的rds是postgresql和时序数据库in ...
- C与ARM汇编结合实现mini2440串口uart简单程序
最近学完了ARM的一些基础知识,开始在mini2440上开发一些简单的程序,串口发送程序是一开始涉及多个寄存器的例子,稍有繁多的步骤应该是开发过程中要慢慢适应的境况 下面的程序的目的是实现mini24 ...
- 《ASP.NET Core 3框架揭秘》读者群,欢迎加入
作为一个17年的.NET开发者,我对一件事特别不能理解:我们的计算机图书市场充斥着一系列介绍ASP.NET Web Forms.ASP.NET MVC.ASP.NET Web API的书籍,但是却找不 ...
- docker安装与环境部署
使用docker搭建环境 摘要 install docker start docker install docker-compose 部署upload-labs/sqli-labs 部署dvwa 部署 ...
- 用 HTML5 造个有诚意的 23D 招聘稿
前言 招聘对于一个公司来说是相当重要的一个环节,首先它影响着公司未来发展的趋势,其次它为公司注入新鲜血液,使公司更具有活力.当然在工业互联网,物联网大背景下诞生的 HT 也是需要注入新鲜的血液来进一步 ...
- apache搭建Tomcat集群(Cluster)
搭建集群: apache:特点处理静态资源(html 图片 js等) apache的请求操作,Cluster工具 tomcat:特点处理动态资源 apache+tomcat(apache是web服 ...
- vue环境搭建过程中,npm权限不足问题
今天在用git bash进行全局安装vue-cli的时候,报错: 必须以管理员权限进行安装才行.所以用cmd命令工具,点击右键命令提示符cmd--------以管理员身份运行--------cd进入到 ...
- # 爬虫连载系列(1)--爬取猫眼电影Top100
前言 学习python有一段时间了,之前一直忙于学习数据分析,耽搁了原本计划的博客更新.趁着这段空闲时间,打算开始更新一个爬虫系列.内容大致包括:使用正则表达式.xpath.BeautifulSoup ...
- Linux apache开启虚拟主机伪静态.htaccess
打开apache配置文件 /etc/httpd/conf/httpd.conf 查找“#LoadModule rewrite_module modules/mod_rewrite.so” 去掉前面的# ...
- 学习RF遇到的问题
1.Windows安装pip命令安装RF报错: File "<stdin>", line 1 pip install robotframework 原因:pip命令不在 ...