观察者模式
优质
小牛编辑
136浏览
2023-12-01
观察者模式
观察者模式可能是我们在软件开发中使用得比较多的一种设计模式。为什么这么说?大家可以听我一一到来。我们知道,在windows的软件中,所有的界都是由窗口构成的。对话框是窗口,菜单是窗口,工具栏也是窗口。那么这些窗口,在很多情况下要对一些共有的信息进行处理。比如说,窗口的放大,窗口的减小等等。面对这一情况,观察者模式就是不错的一个选择。
首先,我们可以对这些共有的object进行提炼。
typedef struct _Object
{
observer* pObserverList[MAX_BINDING_NUMBER];
int number;
void (*notify)(struct _Object* pObject);
void (*add_observer)(observer* pObserver);
void (*del_observer)(observer* pObserver);
}Object;
其实,我们需要定义的就是观察者本身了。就像我们前面说的一样,观察者可以是菜单、工具栏或者是子窗口等等。
typedef struct _Observer
{
Object* pObject;
void (*update)(struct _Observer* pObserver);
}Observer;
紧接着,我们要做的就是在Observer创建的时候,把observer自身绑定到Object上面。
void bind_observer_to_object(Observer* pObserver, Object* pObject)
{
assert(NULL != pObserver && NULL != pObject);
pObserver->pObject = pObject;
pObject->add_observer(pObserver);
}
void unbind_observer_from_object(Observer* pObserver, Object* pObject)
{
assert(NULL != pObserver && NULL != pObject);
pObject->del_observer(observer* pObserver);
memset(pObserver, 0, sizeof(Observer));
}
既然Observer在创建的时候就把自己绑定在某一个具体的Object上面,那么Object发生改变的时候,统一更新操作就是一件很容易的事情了。
void notify(struct _Object* pObject)
{
Obserer* pObserver;
int index;
assert(NULL != pObject);
for(index = 0; index < pObject->number; index++)
{
pObserver = pObjecet->pObserverList[index];
pObserver->update(pObserver);
}
}