四、协议与分类

23,通过委托与数据源协议进行对象间通讯

1,委托模式为对象提供了一套接口,使其可由此将相关事件告知其他对象

2,将委托对象应该支持的接口定义为协议,在协议中把可能需要处理的事件定义为方法

3,当某对象需要从另外一个对象中获取数据时,可以使用委托模式,这种情况下,该模式亦可称为 '数据源协议’。

4,若有必要,可实现含有段位的结构体,将委托对象是否能相应相关协议方法这一信息缓存到其中。


@protocol ScenTest4Delegate <NSObject> // 该协议遵守了NSObject协议

-(void)TestDelegate1:(NSString*)str;

-(void)TestDelegate2:(NSString*)str;

@end


@interfaceSceneTest4()

{

  struct{     //用来第一次检测代理对象是否实现了协议

unsignedintdidTestDelegate1 :  1;//  1是一个字节

unsignedintdidTestDelegate2 :  1;

} _deleagateFlag;

}

//设置代理的时候,就检测过了代理对象是否实现了代理方法

-(void)setDelegate:(id)delegate

{

_delegate= delegate;

_deleagateFlag.didTestDelegate1= [delegaterespondsToSelector:@selector(TestDelegate1:)];

_deleagateFlag.didTestDelegate2= [delegaterespondsToSelector:@selector(TestDelegate2:)];

}

使用时 (这里是不用每次都判断是否都实现了协议)

if(_deleagateFlag.didTestDelegate1) {//这里使用这个判断就好了

[_delegateTestDelegate1:@"111"];

}

这样做的好处是,每次使用代理对象,调用代理方法时,每次都要判断,代理对象是否实现了该代理方法,除了第一次有必要外,后面的很明显就没有必要了。因为我们很少会动态的去掉已经实现了的代理方法。这样,在设置代理的时候,直接就检查了一次,然后缓存到 ‘段位’中,下次之间判断段位就好了


24,将类的实现代码分散到便于管理的数个分类中

1, 使用分类机制吧类的实现代码划分成易于管理的小块中

2,将应该视为'私用'的方法归入名为 'Private'的分类中,以隐藏实现细节

25,总是为第三方类的分类名称加以前缀

1, 向第三方类中添加分类时,总应给其名称加上你专用的前缀

2,也应该给其中的方法加上你专用的前缀

例如:

@interface NSString (DFD_Helper)

- (NSDate *)dfd_toDate;

26, 勿在分类中声明属性

1, 把封装数据所用的全部属性定义在主接口中

2,在'class_contiuation 分类' 之外的其他分类,可以定义存取方法,但尽量不要定义属性

class_continuation 分类 :   在.m上面的分类

属性这是定义实例变量和相关方法所用的‘语法糖’,所以应该遵循实例变量一样的规则。至于分类机制,则应理解为一种手段,目标在与扩展类的类的功能,而非封装数据

27, 使用 ‘class-continuation 分类’隐藏实现细节

1, 通过 ‘class-continuation 分类’ 向类中新增实例变量

2, 如果某属性在主接口(.h)中声明为'只读',而类的内部又要用设置方法修改此属性,那么久在'class-continuation 分类' 中将其扩展为 ‘可读写’

3,把私有方法的原型声明在 ‘class-continuation 分类’里面

4, 如果想是类遵从的协议不为人所知, 则可以在'class-continuation 分类'中声明

28,通过协议提供匿名对象

1, 协议在某种程度上提供匿名类型。具体的对象类型可以淡化为遵循某协议的id类型,协议里规定了对象所应当实现的方法

2, 是用匿名对象类隐藏类型名称(类名)

3,如果具体类型不重要,重要的是对象能够响应(定义在协议中)特定方法,那么可以使用匿名对象来表示

// 如果返回的结果类型不统一,但是都遵循了一个协议,可以这样

-(id)tesDelegate:;

// 具体的类型不重要

id set = ...

[set next];

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容