一、创建方法:

二、实现过程:

1、遵循协议:

@protocol NurseWorkingProtocol <NSObject>   //<> 表示遵守协议,创建时就有(NurseWorkingProtocol.h中)

2、协议内容:(NurseWorkingProtocol.h中)

@required  // 必须做的,默认

- (void)cleanHouse;

@optional  // 可选的

- (void)cook;

3、指定遵循协议的人:(Nurse.h中)

@interface Nurse : NSObject <NurseWorkingProtocol>   // 遵守协议

4、完成协议指定的内容:(Nurse.m中实现)

- (void)cleanHouse {

NSLog(@"打扫房间!");

}

- (void)cook {

NSLog(@"做饭");

}

三、代理委托:(用Custom找Business买iPhone举例)

1、创建协议:(Custom.h中)

@protocol CustomDelegate <NSObject>

- (void)buyIphone:(NSString *)iphoneType;

@end

2、设置代理人:

@property (nonatomic,weak) id<CustomDelegate> delegate;  // 必须遵守协议

3. 找代理人,见Business.h中遵守协议,并在Business.m中实现协议中的方法

@interface Business : NSObject <CustomDelegate>
- (void)buyIphone:(NSString *)iphoneType {

    NSLog(@"%@有货,我帮你买手机", iphoneType);
}

4、上述一切准备就绪,就可以开始买手机啦:(Custom.h中声明方法,在Custom.m中实现如下)

 
- (void)beginBuy {

    //   找到代理人                代理人实现了代理方法,响应方法
if (self.delegate && [self.delegate respondsToSelector:@selector(buyIphone:)]) {
[self.delegate buyIphone:@"iphone7"]; }else {
NSLog(@"代理人不存在或者代理人没有实现代理方法");
}
}

5、在main函数中分别定义一个Custom和Business对象,将Custom对象的代理给business,即找到代理人,然后开始:

custom.delegate = business;  // 找到代理人

[custom beginBuy];           // 开始买

四、通知

1、发布通知:(main.m)

 // 1. custom 发布通知              通知的关键标志 name 用于标识后面接收该通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"buyIphone" object:@"iphone7"];

2、添加观察:(Business.m)

- (instancetype)init {

    self = [super init];

    if (self) {
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(notification:) name:@"buyIphone" object:nil];
}
return self;
}
- (void)notification :(id)noti {
id obj = [noti valueForKey:@"object"]; // ValueForkey 因为是kvc的
NSLog(@"noti = %@", noti);
NSLog(@"object = %@", obj);
} - (void)dealloc { // [[NSNotificationCenter defaultCenter]removeObserver:self]; // 移除所有通知 [[NSNotificationCenter defaultCenter]removeObserver:self name:@"buyIphone" object:nil]; // 移除单条通知 因为是在ARC状态下,所以没有[super dealloc]
}

五、总结:

1. 协议只有声明文件

2. 在遵守协议的类中导入协议的文件,并添加遵守协议  在@interface 后面加尖括号遵守协议

3. @required 必须在.m 中实现, @option 可以不用实现,也即遵守协议做事情

4. 原本类(Nurse.h)中 写@interface Nurse : NSObject <NurseWorkingProtocol>

委托代理

5. 可以单独写一个文件,如上所述,还可以在类中直接写 @protocal 见“代理委托”

6. 对象类型后面加了<协议名>, 则该对象一定得是遵守了这个协议的对象

7. 设置代理人的时候,要用弱引用(weak),而且要遵守过协议的对象才能成为代理人

8. 委托代理使用了回调机制

通知

1. 注册接收通知的观察着

2. 发送通知(postNotification)   ---   接收通知(addObserve)

3. 移除通知 (dealloc 中 remove)

Objective - C 之协议的更多相关文章

  1. Objective中的协议(Protocol)

    Objective中的协议(Protocol) 作用: 专门用来声明一大堆方法. (不能声明属性,也不能实现方法,只能用来写方法的声明). 只要某个类遵守了这个协议.就相当于拥有这个协议中的所有的方法 ...

  2. Objective-C中的类目,延展,协议

    Objective-C中的类目(Category),延展(Extension),协议(Protocol)这些名词看起来挺牛的,瞬间感觉OC好高大上.在其他OOP语言中就没见过这些名词,刚看到这三个名词 ...

  3. Xcode 常用编译选项设置

    Xcode 常用编译选项设置 在xcconfig文件中指定即可. 用标准库连接 LINK_WITH_STANDARD_LIBRARIES = YES如果激活此设置,那么编译器在链接过程中会自动使用通过 ...

  4. Automake

    Automake是用来根据Makefile.am生成Makefile.in的工具 标准Makefile目标 'make all' Build programs, libraries, document ...

  5. Objective-C( Category 分类,非正式协议,分类延展)

    分类: 主要是给原来类增加一些方法;不可以增加成员变量 Person (Person+eat) 非正式协议: 非正式协议就是类别,即凡是NSObject或其子类Foundation框架中的类增加的类别 ...

  6. Objective-C( protocol协议)

    protocol 协议 protocol:用来声明方法 1.协议的定义 @protocol 协议名称 <NSObject> // 方法声明列表.... @end 2.如何遵守协议 1> ...

  7. 【IOS 开发】Objective - C 面向对象高级特性 - 包装类 | 类处理 | 类别 | 扩展 | 协议 | 委托 | 异常处理 | 反射

    一. Objective-C 对象简单处理 1. 包装类 (1) 包装类简介 NSValue 和 NSNumber : -- 通用包装类 NSValue : NSValue 包装单个 short, i ...

  8. 刨根问底Objective-C Runtime

    http://chun.tips/blog/2014/11/05/bao-gen-wen-di-objective%5Bnil%5Dc-runtime-(2)%5Bnil%5D-object-and- ...

  9. Objective-C( Foundation框架 一 字符串)

    Objective-C 中核心处理字符串的类是 NSString 与 NSMutableString ,这两个类最大的区别就是NSString 创建赋值以后该字符串的内容与长度不能在动态的更改,除非重 ...

随机推荐

  1. 面试被问到IIC,总结。

    Linux3.5内核中,IIC. i2c_add_driver i2c_register_driver a. at24cxx_driver放入i2c_bus_type的drv链表 并且从dev链表里取 ...

  2. go字符串转换

    package main import ( "fmt" "strconv" ) /* 常用总结 1.str 转 int a, _ := strconv.Atoi ...

  3. ubuntu 和windows 分别在anaconda上安装tensorflow

    windows下 的anaconda安装tensorflow: 在Anaconda Prompt中:conda install tensorflow python=3.5一直下载失败.总结一下原因可能 ...

  4. Titanic幸存预测分析(Kaggle)

    分享一篇kaggle入门级案例,泰坦尼克号幸存遇难分析. 参考文章: 技术世界,原文链接 http://www.jasongj.com/ml/classification/ 案例分析内容: 通过训练集 ...

  5. php安装redis拓展

    1. 查看是否安装redis库 查看是否安装redis库了.可以通过下面2种方式查看. phpinfo()是否能输出redis的加载信息 在命令行执行`php -m` 输出gd 2. 安装redis库 ...

  6. 笔记-scrapy-selector

    笔记-scrapy-selector scrapy版本:1.5.0 1.总述 scrapy内置selector建立在lxml上. 2.使用 可以使用xpath和css方法来进行解析,两者都返回列表: ...

  7. addClass+siblings+removeClass用意:

    $(this).addClass("li_add").siblings().removeClass("li_add").children('.floor2'). ...

  8. 【LG5019】[NOIP2018]道路铺设

    [LG5019][NOIP2018]道路铺设 题面 洛谷 题解 \(NOIP\) 抄 \(NOIP\)差评 设当前做到了位置\(i\) 且\(h_i\) \(-\) \(h_i\)\(_+\)\(_1 ...

  9. Docker入门篇(三)之docker-compose单机编排

    1.docker-compose的简介 docker-compose作为dokcer的官方编排工具,它可以让用户通过编写一个简单的模板文件,快速地创建和管理基于docker容器的应用集群.实现对doc ...

  10. 【JUC源码解析】ConcurrentLinkedQueue

    简介 ConcurrentLinkedQueue是一个基于链表结点的无界线程安全队列. 概述 队列顺序,为FIFO(first-in-first-out):队首元素,是当前排队时间最长的:队尾元素,当 ...