`
jlaky
  • 浏览: 41969 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Design Patterns in Ruby [Digest 6] Iterator

阅读更多

The Iterator pattern is a technique that allows an aggregate object to provide the outside world with a way to access its collection of subobjects.

In Java we use java.util.Iterator interface to be implemented.

eg. StringTokenizer ResultSet

In Ruby We can write Iterator:

 

class ArrayIterator
  def initialize(array)
    @array = array
    @index = 0
  end
  def has_next?
    @index < @array.length
  end
  def item
    @array[@index]
  end
  def next_item
    value = @array[@index]
    @index += 1
    value
  end
end

 

 

array = ['red', 'green', 'blue']
i = ArrayIterator.new(array)
while i.has_next?
   puts("item: #{i.next_item}")
end

 

The Internal Iterator is:

def for_each_element(array)
  i = 0
  while i < array.length
    yield(array[i])
    i += 1
  end
end

 There are some differences between the two implementations:

external version will be easier to control the process:

"With an external iterator, you won’t call next until you are good and ready for the next element. With an internal iterator, by contrast, the aggregate relentlessly pushes the code block to accept item

after item."

 

"A second advantage of external iterators is that, because they are external, you can share them—you can pass them around to other methods and objects."

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics