观察者模式为您提供了避免组件之间紧密耦合的另一种方法。该模式非常简单:一个对象通过添加一个方法(该方法允许另一个对象,即观察者注册自己)使本身变得可观察。当可观察的对象更改时,它会将消息发送到已注册的观察者。这些观察者使用该信息执行的操作与可观察的对象无关。结果是对象可以相互对话,而不必了解原因。
一个简单示例是系统中的用户列表。下面的代码显示一个用户列表,添加用户时,它将发送出一条消息。添加用户时,通过发送消息的日志观察者可以观察此列表。
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
42
43
|
<?php
//首先定义观察者接口
interface
IObserver {
//发生变化的时候观察者的动作
function
onChange(
$sender
,
$args
) ;
}
//定义被观察者接口
interface
IObservable {
//注册观察者的方法
function
addObserver(
$observer
);
}
//定义用户列表类,继承被观察者类
class
UserList
implements
IObservable {
//注册的观察者列表
private
$_observers
=
array
();
//添加用户的方法
public
function
addCustomer(
$name
) {
foreach
(
$this
->_observers
as
$obs
) {
$obs
->onChange(
$this
,
$name
);
}
}
//注册观察者的方法
public
function
addObserver(
$observer
) {
$this
->_observers[] =
$observer
;
}
}
//定义用户日志类,也可以是其他的一些操作,继承观察者
class
UserListLogger
implements
IObserver {
//实现观察者的方法
public
function
onChange(
$sender
,
$args
){
//这里可以实现当观察者检测到观察事件的时候定义的动作
//比方说发送欢迎邮件之类的
echo
"$args added to user list\n"
;
}
}
//实例化观察者
$userListLogger
=
new
UserListLogger();
//实例化被观察者
$userList
=
new
UserList();
//注册观察者
$userList
->addObserver(
$userListLogger
);
//注册用户,观察者发生动作
$userList
->addCustomer(
'jane'
);
|
本文转自shayang8851CTO博客,原文链接:http://blog.51cto.com/janephp/1343405,如需转载请自行联系原作者