迭代器模式(Iterator),又称为游标模式(Cursor)
产生背景:容器用来存放数据,当用户需要遍历里面的数据时,如果将遍历算法放置在容器内部,那么会使容器承担太多东西,而如果选择让用户自己实现遍历算法,那么又会暴露容器的内部细节,所以创建一个迭代器,将遍历算法放置到迭代器里,然后在容器内部声明一个返回关于如何遍历自己的迭代器的方法供用户使用,这样就避免了上诉的2个问题了,迭代器也由此而生
定义:提供一种方法顺序访问一个容器对象中的各个元素,同时又不需要暴露该对象的内部表示
一般迭代器的抽象接口需要声明的几个需要实现的方法:hasNext、next、moveToFirst、moveToNext等
一般情况下,Coder不需要自己去实现一个迭代器,使用系统已经实现的迭代器即可,比如内容提供器和数据库的Cursor,List、Map的Iterator
简述2个其他的模式:
1. 代理模式:
定义:为其他对象提供一种代理,以控制对这个对象的访问
适用场景:当无法或者不想直接访问某个对象或访问某个对象存在困难的时候,可以通过一个代理对象来间接地访问,为了保证客户端使用的透明性,委托对象与代理对象需要实现相同的接口,比如AIDL的内部实现
2. 适配器模式:
适配器模式,是将2个不兼容的类融合在一起,又点像粘合剂,将不同的东西通过一种转换使得它们能够协作起来,比如ListView和子项布局的不兼容,就是使用适配器动态的加载子项布局,然后适配起来
定义:把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作