简单例子让你很好的理解:协议与委托 (Protocol and Delegate)

2024-08-22 18:58

本文主要是介绍简单例子让你很好的理解:协议与委托 (Protocol and Delegate),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 协议:

协议,类似于Java或C#语言中的接口,它限制了实现类必须拥有哪些方法。
它是对对象行为的定义,也是对功能的规范。
示例:

1
2
3
4
5
6
7
8
9
// GoodChild.h

#import <Foundation/Foundation.h>

@protocol GoodChild <NSObject>

- ( void )filialPiety;

@end

 

1
2
3
4
5
6
7
8
// Student.h

#import <Foundation/Foundation.h>
#import "GoodChild.h"
//注意实现协议的语法。
@interface Student  : NSObject<GoodChild>

@end

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// Student.m
// protocol
//
// Created by sxt on 11-10-23.
// Copyright 2011年 __MyCompanyName__. All rights reserved.
//

#import "Student.h"

@implementation Student

-  ( id )init
{
self  =  [super init ];
if  (self )  {
// Initialization code here.
}

return self;
}
- ( void )filialPiety {
NSLog ( @ "孝敬父母。。" );
}
@end

此例中定义了一个协议GoodChild,类Student实现了此协议,所以必须有filialPiety方法。
每个类虽只有一个父类,但可以实现多个协议,以逗号隔开便可。语法如下:

1
2
3
@interface Student  : NSObject<协议 1,协议 2>

@end

2 委托:

委托是objC中使用非常频繁的一种设计模式,它的实现与协议的使用是分不开的,让我们看一个综合示例:
小公司老板日常的工作是管理公司、教导新员工、发工资与接电话。
其中管理公司、教导新员工是老板要亲为的。
而发工资与接电话老板希望招聘一个秘书来帮忙,于是对秘书的要求就是要略懂出纳发工资,要能帮助领导接电话。 而这两项要求便是协议,对类功能的限定。

1
2
3
4
5
6
7
8
9
10
11
// SecProtocol.h

#import <Foundation/Foundation.h>

@protocol SecProtocol <NSObject>
//发工资
- ( void )payoff;
//接电话
- ( void )tel;

@end

然后定义一个秘书类

1
2
3
4
5
6
7
// Sec.h

#import <Foundation/Foundation.h>
#import "SecProtocol.h"
@interface Sec  : NSObject<SecProtocol>

@end

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
// Sec.m

#import "Sec.h"

@implementation Sec

-  ( id )init
{
self  =  [super init ];
if  (self )  {
// Initialization code here.
}

return self;
}

- ( void )payoff {
NSLog ( @ "sec payoff" );
}

- ( void )tel {
NSLog ( @ "sec tel" );
}

@end

紧接着是老板类:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
// Boss.h

#import <Foundation/Foundation.h>
#import "SecProtocol.h"
@interface Boss  :  NSObject

//此属性用于指定秘书对象,此对象必须实现SecProtocol协议。
@property (nonatomic,retain ) id<SecProtocol> detegate;
//管理
- ( void )manage;
//教导新员工
- ( void )teach;

@end

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
// Boss.m
#import "Boss.h"

@implementation Boss

@synthesize detegate =_detegate;

-  ( id )init
{
self  =  [super init ];
if  (self )  {
// Initialization code here.
}

return self;
}

- ( void )manage {
NSLog ( @ "boss manage" );
}

- ( void )teach {
NSLog ( @ "boss teach" );
}

- ( void )payoff {

NSAutoreleasePool  *p = [ [ NSAutoreleasePool alloc ] init ];
[_detegate payoff ];
[p release ];

}

- ( void )tel {

NSAutoreleasePool  *p = [ [ NSAutoreleasePool alloc ] init ];
[_detegate tel ];
[p release ];

}
@end

那么老板就具有这4个方法,当调用前2个时是自己完成功能,而调用后2个时则转为调用秘书的方法。
此时我们跟秘书对象就叫做代理对象,代理模式的名字由来于此。
最后调用测试下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// main.m
// delegate
//
// Created by sxt on 11-10-23.
// Copyright 2011年 Jinlong Wei. All rights reserved.
//

#import <Foundation/Foundation.h>
#import "Boss.h"
#import "Sec.h"
int main  ( int argc,  const  char  * argv [ ] )
{

NSAutoreleasePool  * pool  =  [ [ NSAutoreleasePool alloc ] init ];

//实例化老板对象
Boss  *boss = [ [ [Boss alloc ] init ] autorelease ];
//实例化秘书对象
Sec  *sec = [ [ [Sec alloc ] init ] autorelease ];

//设置老板的代理对象为秘书
boss.detegate =sec;

//调用4个方法。
[boss payoff ];
[boss tel ];
[boss manage ];
[boss teach ];
[pool drain ];
return  0;
}

转载请注明:dApps开发者 » 【iOS开发】协议与委托 (Protocol and Delegate) 实例解析

这篇关于简单例子让你很好的理解:协议与委托 (Protocol and Delegate)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。