Python week November Black Friday
This week up to 80% off on Python courses. More info
Black friday is here! Get up to 80 % extra points for free! More info

Iterator

The Iterator design pattern introduces an external object that allows to go through the items of collections without knowing the internal structure of the collections. This is one of the most popular pattern, and you can find it implemented in standard libraries of almost all programming languages. Sometimes, it's called Enumerator instead of Iterator.

Motivation

Today's programming languages often provide rich variety of collections, i.e., arrays, lists, dictionaries (hashmap), but also e.g. trees. Sometimes, it's useful to implement our own collection, especially if it's supposed to provide some special operations over its elements. At some point, we need to iterate through every collection, i.e. to go through all its elements from the first to the last one and print them, for example. If each collection implemented its own interface to iterate over its elements, first, we'd have to examine them, and collections are sometimes really complicated. And second, the language itself won't be able to support syntactic sugar such as the foreach loop. If you think of introducing some general interface the


 

...End of the preview...

Premium article

Premium article

ict.social is a large database made up of manuals and tutorials, whose main goal is to provide high-quality IT education to everyone. We started out in the Czech republic, where we display roughly a million articles per month and receive plenty of gratitude from our users. Thanks to our successful establishment, we are now bringing these articles to the rest of the world.

Although we are trying to keep our content free of charge, maintaining the site is a huge effort for everyone involved. Therefore, some content (exercises and more advanced material) costs network points. Don't worry, they're really cheap :)

Article description

Requested article covers this content:

The Iterator design pattern introduces an external object that allows to go through a collection linearly without having to know its internal structure.

Limited offer: Learn all knowledge and save money

Buy articles and tests separately one by one 30 points
Buy the course including all articles and features for an exclusive price 26 points
Currently, you have 0 points
By buying this exclusive package, you'll have access to all 9 articles in this course including exercise submitting while saving $0.40. This offer is limited for the first articles only with an additional exclusive 15% discount.
You gain 26 points for adding an article to the site, or for $2.70 $2.29

Buy just this article

Warning, by buying just this article you'll lose the limited 15% discount for the package of all the articles.

To access the article, you need 10 points
Currently, you have 0 points
You gain 10 points for adding an article to the site, or for $0.90

Buying this article gives you unlimited access to it forever. You will learn some more and help us keep giving our site maintenance which helps you and others get better futures. It's a win-win.

This article is licensed :Premium, by buying this article, you agree with the terms of use.

You gain points by supporting our network. This is done by sending a helpful amount of money to support the site, or by creating content for the network.

You can get points immediately using:

Credit card SMS Wire transfer
Credit card SMS Wire transfer

 

Article has been written for you by David Capka
Avatar
The author is a programmer, who likes web technologies and being the lead/chief article writer at ICT.social. He shares his knowledge with the community and is always looking to improve. He believes that anyone can do what they set their mind to.
Unicorn College The author learned IT at the Unicorn College - a prestigious college providing education on IT and economics.
Previous article
Mediator
All articles in this section
GOF - Behavioral Patterns
Thumbnail
Next article
Chain of Responsibility
Activities (2)