Objective-C之代理设计模式小实例

*:first-child {
margin-top: 0 !important; }
body > *:last-child {
margin-bottom: 0 !important; }

a {
color: #4183C4; }
a.absent {
color: #cc0000; }
a.anchor {
display: block;
padding-left: 30px;
margin-left: -30px;
cursor: pointer;
position: absolute;
top: 0;
left: 0;
bottom: 0; }

h1, h2, h3, h4, h5, h6 {
margin: 20px 0 10px;
padding: 0;
font-weight: bold;
-webkit-font-smoothing: antialiased;
cursor: text;
position: relative; }

h1:hover a.anchor, h2:hover a.anchor, h3:hover a.anchor, h4:hover a.anchor, h5:hover a.anchor, h6:hover a.anchor {
background: url() no-repeat 10px center;
text-decoration: none; }

h1 tt, h1 code {
font-size: inherit; }

h2 tt, h2 code {
font-size: inherit; }

h3 tt, h3 code {
font-size: inherit; }

h4 tt, h4 code {
font-size: inherit; }

h5 tt, h5 code {
font-size: inherit; }

h6 tt, h6 code {
font-size: inherit; }

h1 {
font-size: 28px;
color: black; }

h2 {
font-size: 24px;
border-bottom: 1px solid #cccccc;
color: black; }

h3 {
font-size: 18px; }

h4 {
font-size: 16px; }

h5 {
font-size: 14px; }

h6 {
color: #777777;
font-size: 14px; }

p, blockquote, ul, ol, dl, li, table, pre {
margin: 15px 0; }

hr {
background: transparent url() repeat-x 0 0;
border: 0 none;
color: #cccccc;
height: 4px;
padding: 0;
}

body > h2:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child {
margin-top: 0;
padding-top: 0; }
body > h1:first-child + h2 {
margin-top: 0;
padding-top: 0; }
body > h3:first-child, body > h4:first-child, body > h5:first-child, body > h6:first-child {
margin-top: 0;
padding-top: 0; }

a:first-child h1, a:first-child h2, a:first-child h3, a:first-child h4, a:first-child h5, a:first-child h6 {
margin-top: 0;
padding-top: 0; }

h1 p, h2 p, h3 p, h4 p, h5 p, h6 p {
margin-top: 0; }

li p.first {
display: inline-block; }
li {
margin: 0; }
ul, ol {
padding-left: 30px; }

ul :first-child, ol :first-child {
margin-top: 0; }

dl {
padding: 0; }
dl dt {
font-size: 14px;
font-weight: bold;
font-style: italic;
padding: 0;
margin: 15px 0 5px; }
dl dt:first-child {
padding: 0; }
dl dt > :first-child {
margin-top: 0; }
dl dt > :last-child {
margin-bottom: 0; }
dl dd {
margin: 0 0 15px;
padding: 0 15px; }
dl dd > :first-child {
margin-top: 0; }
dl dd > :last-child {
margin-bottom: 0; }

blockquote {
border-left: 4px solid #dddddd;
padding: 0 15px;
color: #777777; }
blockquote > :first-child {
margin-top: 0; }
blockquote > :last-child {
margin-bottom: 0; }

table {
padding: 0;border-collapse: collapse; }
table tr {
border-top: 1px solid #cccccc;
background-color: white;
margin: 0;
padding: 0; }
table tr:nth-child(2n) {
background-color: #f8f8f8; }
table tr th {
font-weight: bold;
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr td {
border: 1px solid #cccccc;
margin: 0;
padding: 6px 13px; }
table tr th :first-child, table tr td :first-child {
margin-top: 0; }
table tr th :last-child, table tr td :last-child {
margin-bottom: 0; }

img {
max-width: 100%; }

span.frame {
display: block;
overflow: hidden; }
span.frame > span {
border: 1px solid #dddddd;
display: block;
float: left;
overflow: hidden;
margin: 13px 0 0;
padding: 7px;
width: auto; }
span.frame span img {
display: block;
float: left; }
span.frame span span {
clear: both;
color: #333333;
display: block;
padding: 5px 0 0; }
span.align-center {
display: block;
overflow: hidden;
clear: both; }
span.align-center > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: center; }
span.align-center span img {
margin: 0 auto;
text-align: center; }
span.align-right {
display: block;
overflow: hidden;
clear: both; }
span.align-right > span {
display: block;
overflow: hidden;
margin: 13px 0 0;
text-align: right; }
span.align-right span img {
margin: 0;
text-align: right; }
span.float-left {
display: block;
margin-right: 13px;
overflow: hidden;
float: left; }
span.float-left span {
margin: 13px 0 0; }
span.float-right {
display: block;
margin-left: 13px;
overflow: hidden;
float: right; }
span.float-right > span {
display: block;
overflow: hidden;
margin: 13px auto 0;
text-align: right; }

code, tt {
margin: 0 2px;
padding: 0 5px;
white-space: nowrap;
border: 1px solid #eaeaea;
background-color: #f8f8f8;
border-radius: 3px; }

pre code {
margin: 0;
padding: 0;
white-space: pre;
border: none;
background: transparent; }

.highlight pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }

pre {
background-color: #f8f8f8;
border: 1px solid #cccccc;
font-size: 13px;
line-height: 19px;
overflow: auto;
padding: 6px 10px;
border-radius: 3px; }
pre code, pre tt {
background-color: transparent;
border: none; }

sup {
font-size: 0.83em;
vertical-align: super;
line-height: 0;
}
* {
-webkit-print-color-adjust: exact;
}
@media screen and (min-width: 914px) {
body {
width: 854px;
margin:0 auto;
}
}
@media print {
table, pre {
page-break-inside: avoid;
}
pre {
word-wrap: break-word;
}
}
-->

代理设计模式小实例

协议的应用场景之一:代理模式

需求:

用代理实现学生找房子, 不具备找房子的能力
所以学生可以找另一个对象来帮它找房子, 那么另一个对象就是学生的代理

UML类图:

Objective-C之代理设计模式小实例

类图关系分析:

+ 两个对象:Student(学生用户),LinkHouse(代理者)
+ LinkHouse是属于Student的代理,所以这里是(has a)拥有的组合关系
+ 所以:LinkHouse对象可以作为Student类里的一个对象数据类型的属性
+ 另外:因为不确定代理的具体类型,用id万能数据类型作为属性的声明类型
+ 在这里id数据类型后面需要<代理的名称>,例:id \<LinkHouse\>。
- 协议写在数据类型的右边, 明确的标注如果想给该变量赋值, 那么该对象必须遵守某个协议

代码使用代理需要注意的地方

  • Student的需求方法中(这里是findHouse找房子的行为)调用代理者(LinkHouse)的所能提供的方法(比如findHouse,要是这个代理不能满足需求用户的需求,那留他有啥用)

  • 协议一般都是需求用户提出来的协议,比如我去相亲,对对方我心里肯定或多或少对对方有一些基本要求(比如会洗衣服做饭什么的),这些就是我提出来的协议。所以要遵循协议的编写规范(比如:一般情况下, 当前协议属于谁, 我们就将协议定义到谁的头文件中)

  • 协议的编写规范:

    • 1.一般情况下, 当前协议属于谁, 我们就将协议定义到谁的头文件中
    • 2.协议的名称一般以它属于的那个类的类名开头, 后面跟上protocol或者delegate
    • 3.协议中的方法名称一般以协议的名称protocol之前的作为开头
    • 4.一般情况下协议中的方法会将触发该协议的对象传递出去
    • 5.一般情况下一个类中的代理属于的名称叫做 delegate
    • 6.当某一个类要成为另外一个类的代理的时候, 一般情况下在.h中用@protocol 协议名称;告诉当前类 这是一个协议.在.m中用#import真正的导入一个协议的声明

接下来进入实例代码阶段:

Student.h代码:

 #import <Foundation/Foundation.h>
#import "StudentFindHouse.h"
@class LinkHouse; @interface Student : NSObject @property (nonatomic,strong)id<StudentFindHouse> delegate; -(void)findHouse; @end

Student.m代码:

 #import "Student.h"
#import "LinkHouse.h" @implementation Student -(void)findHouse{
if ([self.delegate respondsToSelector:@selector(findHouse)]) {
[self.delegate findHouse];
}
} @end

然后写出Student的类的协议,StudentFindHouse.h:

 #import <Foundation/Foundation.h>

 @protocol StudentFindHouse <NSObject>

 -(void)findHouse;

 @end

LinkHouse.h代码:

 #import <Foundation/Foundation.h>

 #import "StudentFindHouse.h"

 @interface LinkHouse : NSObject <StudentFindHouse>

 -(void)findHouse;

 @end

LinkHouse.m代码:

 #import "LinkHouse.h"

 @implementation LinkHouse 

 -(void)findHouse{
NSLog(@"%s 帮student找房子。",__FUNCTION__);
} @end

main.m代码以及然后运行的结果:

Objective-C之代理设计模式小实例

 
 
 
 
上一篇:CentOS/ubuntu/Solaris软件包安装


下一篇:xmapp上搭建dvwa