【寒江雪】Go实现迭代器模式

Iterator Pattern

  迭代器模式可以把对象的访问方式给封装出来,只需要给某种数据结构实现自己的迭代器,用户只需要拿到迭代器就可以轻易操作该数据结构,而不需要在乎底层实现。

实现

封装一个容器

package iterator

import "container/list"

type Container interface{
    Iterator()Iterator
}

type List struct{
    list list.List
}

func (this *List)Iterator()Iterator{
    return &ListIterator{this.list.Front(),this.list.Back()}
}

func (this *List)Add(value interface{}){
    this.list.PushBack(value)
}

为容器实现迭代器

package iterator

import (
    "container/list"
)

type Iterator interface{
    HasNext()bool
    Value()interface{}
    Next()
}

type ListIterator struct {
    cur *list.Element
    end *list.Element
}

func (this *ListIterator)HasNext()bool{
    return this.cur != this.end
}

func (this *ListIterator)Next(){
    this.cur=this.cur.Next()
}

func (this *ListIterator)Value()interface{}{
    return this.cur.Value
}

main.go

package main

import (
    "projects/DesignPatternsByGo/behavioralPatterns/iterator"
    "fmt"
)

func main() {
    l := iterator.List{}
    l.Add(1)
    l.Add(2)
    l.Add(3)
    l.Add(4)
    i := l.Iterator()
    for i.HasNext(){
        x := i.Value().(int)
        fmt.Println(x)
        i.Next()
    }
}

猜你喜欢

转载自blog.csdn.net/lkysyzxz/article/details/79662068