La class java.util.Vector est sans doute une des classes Java les plus pratiques. Depuis la sortie de Java 1.2 lorsque vous devez énumerer (lister) le contenu d’un Vector, vous pouvez utiliser la méthode « à l’ancienne » comme dans cet exemple:
Vector v=new Vector(); String prenom=new String("Arnold"); String nom=new String("Governator of California"); Integer numb=new Integer(3); v.addElement(prenom); v.addElement(nom); v.addElement(numb); for(Enumeration e=v.elements() ; e.hasMoreElements() ; ) { System.out.println(e.nextElement()); }
Lorsque ce programme est executé nous obtenons:
Arnold Governator of California 3
Maintenant si je rajoute à ce programme la version java 1.2 utilisant un iterator nous avons:
Vector v = new Vector(); String prenom = new String("Arnold"); String nom = new String("Governator of California"); Integer numb = new Integer(3); v.addElement(prenom); v.addElement(nom); v.addElement(numb); System.out.println("Version java 1.1:"); for (Enumeration e = v.elements(); e.hasMoreElements();) { System.out.print(e.nextElement()); System.out.print(' '); } System.out.println("\nVersion java 1.2:"); for(Iterator i=v.iterator() ; i.hasNext();){ System.out.print(i.next()); System.out.print(' '); }
L’execution donnera:
Version java 1.1: Arnold Governator of California 3 Version java 1.2: Arnold Governator of California 3
La question est la suivante: quelle est la différence entre un Iterator et une Enumeration ? la réponse se trouve dans la javadoc de la classe java.util.Vector dans ce paragraphe:
[…]The Iterators returned by Vector’s iterator and listIterator methods are fail-fast: if the Vector is structurally modified at any time after the Iterator is created, in any way except through the Iterator’s own remove or add methods, the Iterator will throw a ConcurrentModificationException. Thus, in the face of concurrent modification, the Iterator fails quickly and cleanly, rather than risking arbitrary, non-deterministic behavior at an undetermined time in the future. The Enumerations returned by Vector’s elements method are not fail-fast.
En clair cela veut dire que si vous utilisez un Iterator lors de la lecture du Vector, vous êtes assuré que si quelqu’un venait à modifier un des élements du vecteur, alor une exception ConcurrentModificationException
sera levée, ce qui n’est pas le cas lorsque l’on utilise une Enumeration. Dans le cas d’un programme mutli-threadé, il est donc important d’utiliser ce nouveau moyen pour s’assurer que les données utilisées sont consistantes.