jeudi 15 octobre 2015

Violation of single responsibility principle in Iterator from Java core

Why java.util.Iterator interface has method remove()?

Certainly sometimes this method is necessary and all have become accustomed to its presence. But in fact the main and only objective of the iterator is just to provide access container elements. And when someone wants to create his own implementation for this interface, and cannot or does not want for any reason to provide the ability to remove an element, then he is forced to throw UnsupportedOperationException. And throwing of that exception usually indicates a not too well thought out architecture or some flaws in design.

Really I don't understand the reasons for such a decision. And I guess it would be more correctly separate a specific subinterface to support the optional method: diagram

Any reasoned versions why remove() is part of the Iterator? Is not this example of a direct violation of the single responsibility principle from SOLID?

Aucun commentaire:

Enregistrer un commentaire