一、迭代器模式
类型: 行为型模式
目的: 用于顺序访问集合对象的元素,使用者不需要知道集合对象的底层表示。
二、例子
2.1 菜鸟例子
2.1.1 定义迭代器接口
public interface Iterator {
public boolean hasNext();
public Object next();
}
2.1.2 定义迭代对象接口——用于返回一个迭代器
public interface Container {
public Iterator getIterator();
}
2.1.3 实现 迭代对象 和 迭代器
public class NameRepository implements Container {
public String[] names = {"Robert" , "John" ,"Julie" , "Lora"};
@Override
public Iterator getIterator() {
return new NameIterator();
}
private class NameIterator implements Iterator {
int index;
@Override
public boolean hasNext() {
if(index < names.length){
return true;
}
return false;
}
@Override
public Object next() {
if(this.hasNext()){
return names[index++];
}
return null;
}
}
}
2.1.4 使用
public class IteratorPatternDemo {
public static void main(String[] args) {
NameRepository namesRepository = new NameRepository();
for(Iterator iter = namesRepository.getIterator(); iter.hasNext();){
String name = (String)iter.next();
System.out.println("Name : " + name);
}
}
}
2.2 JDK源码——ArrayList
private static class ArrayList<E> extends AbstractList<E> implements RandomAccess, java.io.Serializable {
@Override
public Iterator<E> iterator() {
return new ArrayItr<>(a);
}
}
private static class ArrayItr<E> implements Iterator<E> {
private int cursor;
private final E[] a;
ArrayItr(E[] a) {
this.a = a;
}
@Override
public boolean hasNext() {
return cursor < a.length;
}
@Override
public E next() {
int i = cursor;
if (i >= a.length) {
throw new NoSuchElementException();
}
cursor = i + 1;
return a[i];
}
}
2.3 Spring源码——DefaultListableBeanFactory
public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable {
private volatile List<String> beanDefinitionNames;
private volatile Set<String> manualSingletonNames;
public Iterator<String> getBeanNamesIterator() {
CompositeIterator<String> iterator = new CompositeIterator();
iterator.add(this.beanDefinitionNames.iterator());
iterator.add(this.manualSingletonNames.iterator());
return iterator;
}
}
迭代器CompositeIterator
public class CompositeIterator<E> implements Iterator<E> {
private final Set<Iterator<E>> iterators = new LinkedHashSet();
private boolean inUse = false;
public CompositeIterator() {
}
public void add(Iterator<E> iterator) {
Assert.state(!this.inUse, "You can no longer add iterators to a composite iterator that's already in use");
if (this.iterators.contains(iterator)) {
throw new IllegalArgumentException("You cannot add the same iterator twice");
} else {
this.iterators.add(iterator);
}
}
public boolean hasNext() {
this.inUse = true;
Iterator var1 = this.iterators.iterator();
Iterator iterator;
do {
if (!var1.hasNext()) {
return false;
}
iterator = (Iterator)var1.next();
} while(!iterator.hasNext());
return true;
}
public E next() {
this.inUse = true;
Iterator var1 = this.iterators.iterator();
Iterator iterator;
do {
if (!var1.hasNext()) {
throw new NoSuchElementException("All iterators exhausted");
}
iterator = (Iterator)var1.next();
} while(!iterator.hasNext());
return iterator.next();
}
public void remove() {
throw new UnsupportedOperationException("CompositeIterator does not support remove()");
}
}
三、其他设计模式
创建型模式
结构型模式文章来源:https://www.toymoban.com/news/detail-744530.html
- 1、设计模式——装饰器模式(Decorator Pattern)+ Spring相关源码
行为型模式文章来源地址https://www.toymoban.com/news/detail-744530.html
- 1、设计模式——访问者模式(Visitor Pattern)+ Spring相关源码
- 2、设计模式——中介者模式(Mediator Pattern)+ JDK相关源码
- 3、设计模式——策略模式(Strategy Pattern)+ Spring相关源码
- 4、设计模式——状态模式(State Pattern)
- 5、设计模式——命令模式(Command Pattern)+ Spring相关源码
- 6、设计模式——观察者模式(Observer Pattern)+ Spring相关源码
- 7、设计模式——备忘录模式(Memento Pattern)
- 8、设计模式——模板方法模式(Template Pattern)+ Spring相关源码
- 9、设计模式——迭代器模式(Iterator Pattern)+ Spring相关源码
- 10、设计模式——责任链模式(Chain of Responsibility Pattern)+ Spring相关源码
- 11、设计模式——解释器模式(Interpreter Pattern)+ Spring相关源码
到了这里,关于设计模式——迭代器模式(Iterator Pattern)+ Spring相关源码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!