Observer观察者模式
2013-11-25 12:48
183 查看
概念:定義了對象間的一對多的關係,即一個被觀察者和多個觀察者,當被觀察者狀態改變時就會通知觀察者。
這是一種松耦合的OO設計,為什麼?
指的是主題(被觀察者)和觀察者之間是松耦合的,主題包含了一個觀察者列表,當狀態改變時,通知列表中的所有觀察者即可,如需觀察主題,只需在主題中註冊,如不想觀察,只需主題取消相應的觀察者,這些對主題和觀察者本身及之間的聯繫不影響。
![](http://img.blog.csdn.net/20131125125823171?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvRF9TX1BBTg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
以上是J***A内置的API
继承Obeserable类即是被观察者,实现Observer接口即是观察者,Observable痛过addObservable添加观察者到观察者列表,然后有状态改变时,先调用setChange来标记状态已经改变,然后调用notifyObservers来通知观察者,通过调用Observer的onUpdate来通知。
有一点的不足,Observable是一个类而不是接口,java只支持类的单继承,所以不利于扩展
举例:
1、 在android中的BaseAdapter和listview的关系就是一种观察者模式。
BaseAdapter中有个Observable类型的成员变量,在ListView中有个AdapterDataSetObserver类型的成员变量,当ListView在设置adapter的时候就会注册为BaseAdapter的观察者,所以当BaseAdapter在数据变更时调用notifyDataSetChange就会通知到ListView去回调requestLayout()来刷新界面。
AdapterDataSetObserver是AdapterView的一个内部类
這是一種松耦合的OO設計,為什麼?
指的是主題(被觀察者)和觀察者之間是松耦合的,主題包含了一個觀察者列表,當狀態改變時,通知列表中的所有觀察者即可,如需觀察主題,只需在主題中註冊,如不想觀察,只需主題取消相應的觀察者,這些對主題和觀察者本身及之間的聯繫不影響。
以上是J***A内置的API
继承Obeserable类即是被观察者,实现Observer接口即是观察者,Observable痛过addObservable添加观察者到观察者列表,然后有状态改变时,先调用setChange来标记状态已经改变,然后调用notifyObservers来通知观察者,通过调用Observer的onUpdate来通知。
有一点的不足,Observable是一个类而不是接口,java只支持类的单继承,所以不利于扩展
举例:
1、 在android中的BaseAdapter和listview的关系就是一种观察者模式。
BaseAdapter中有个Observable类型的成员变量,在ListView中有个AdapterDataSetObserver类型的成员变量,当ListView在设置adapter的时候就会注册为BaseAdapter的观察者,所以当BaseAdapter在数据变更时调用notifyDataSetChange就会通知到ListView去回调requestLayout()来刷新界面。
public abstract class BaseAdapter implements ListAdapter, SpinnerAdapter { private final DataSetObservable mDataSetObservable = new DataSetObservable(); public void registerDataSetObserver(DataSetObserver observer) { mDataSetObservable.registerObserver(observer); } public void unregisterDataSetObserver(DataSetObserver observer) { mDataSetObservable.unregisterObserver(observer); } public void notifyDataSetChanged() { mDataSetObservable.notifyChanged();
AdapterDataSetObserver是AdapterView的一个内部类
class AdapterDataSetObserver extends DataSetObserver { private Parcelable mInstanceState = null; @Override public void onChanged() { mDataChanged = true; mOldItemCount = mItemCount; mItemCount = getAdapter().getCount(); // Detect the case where a cursor that was previously invalidated has // been repopulated with new data. if (AdapterView.this.getAdapter().hasStableIds() && mInstanceState != null && mOldItemCount == 0 && mItemCount > 0) { AdapterView.this.onRestoreInstanceState(mInstanceState); mInstanceState = null; } else { rememberSyncState(); } checkFocus(); requestLayout(); }
相关文章推荐
- Android中的共享设置(SharedPreferences)
- 随机密码
- SQL 级联更新,级联删除的概念
- 根据终端判断跳转
- SQL级联更新,级联删除
- 内部类
- 算法习题67(1):扑克牌顺子游戏
- jsp验证码
- uva10673 - Play with Floor and Ceil 扩展欧几里德算法
- TFS二次开发系列:八、TFS二次开发的数据统计以PBI、Bug、Sprint等为例(二)
- 1012 A + B的输入输出练习(三)
- 读写锁pthread_rwlock_t的使用
- cocos2d-x 使用schedule实现倒计时
- SUSE Linux Enterprise Server 11 SP1安装图解教程
- 那些年曾经看过的电影之猛男系列
- 现代程序设计——homework-06
- Java正则表达式实现web端输入验证
- MFC/C++/C中字符类型CString, int, string, char*之间的转换
- 1010 A+B for Input-Output Practice (I)
- 求出并输出Fibnacci序列的第20个数