


Quelle est la différence entre la boucle for et la boucle foreach en Java ?
(1) Traversée d'éléments
Prenons d'abord un morceau de code comme exemple :
String[] array = {"1", "2", "3"}; for (String i : array) { System.out.println(i); } ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); for (String i : list) { System.out.println(i); }
Les résultats après traversée sont les suivants :
1
2
3
111
222
333
Le résultat cela ne fait aucun doute.
Jetons un coup d'œil au code source compilé (cela vient avec une idée, ouvrez simplement le fichier de code source de votre classe dans le package cible) :
String[] array = new String[]{"1", "2", "3"}; String[] var2 = array; int var3 = array.length; for(int var4 = 0; var4 < var3; ++var4) { String i = var2[var4]; System.out.println(i); } ArrayList<String> list = new ArrayList(); list.add("111"); list.add("222"); list.add("333"); Iterator var7 = list.iterator(); while(var7.hasNext()) { String i = (String)var7.next(); System.out.println(i); }
On peut voir que la boucle for originale est utilisée pour parcourir le tableau, et le L'itérateur est utilisé pour la collection.
(2) Supprimer l'élément
Oh putain ! Supprimons ensuite les éléments :
Utiliser la boucle for :
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (int i = 0; i <list.size(); i++) { list.remove("222"); } log.info(list.toString());
Résultat :
11:11:52.532 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333]
11:11 :52.539 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 333]
Évidemment réussi !
Utiliser foreach :
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (String i : list) { list.remove("222"); } log.info(list.toString());
Résultat :
11:50:48.333 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333]
Exception dans le fil "main" java.util.ConcurrentModificationException
sur java.util.ArrayList$Itr.checkForComodification(ArrayList.java:909)
sur java.util.ArrayList$Itr.next(ArrayList.java:859)
sur com.xiaolinge.com.hello.HelloWord.main( HelloWord.java:30)
Évidemment pas réussi !
Raison :
Chaque itération à l'intérieur de l'itérateur enregistrera le modcount à l'intérieur de la liste comme valeur attendue, puis utilisera la valeur attendue pour comparer avec la variable membre modCount de la liste dans chaque boucle, mais les appels list.remove ordinaires List Remove, puis modcount++, mais la valeur attendue = enregistrée dans l'itérateur n'a pas changé, donc une erreur sera signalée.
Si vous souhaitez supprimer des éléments, vous devez utiliser la méthode Remove à l'intérieur de l'itérateur :
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); Iterator<String> it = list.iterator(); while (it.hasNext()){ String next = it.next(); //if外使用list的remove方法还是会报错的 if(next.equals("222")){ it.remove();//这里使用的是迭代器里面的remove()方法, // 当然如果使用list的remove方法在此删除质地感元素的话是成功的,比如:list.remove("222") } } log.info(list.toString());
Result :
12:06:14.042 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222 , 333]
12:06:14.046 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 333]
(3) Modifier l'élément
Utiliser l'original pour :
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (int i = 0; i <list.size(); i++) { list.set(i,"444"); } log.info(list.toString());
Résultat :
12:12 :56.910 [principal] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333]
12:12:56.915 [principal] INFO com.xiaolinge.com.hello.HelloWord - [444, 444 , 444]
Oh mon Dieu ! Les éléments peuvent être modifiés ;
Utiliser foreach :
ArrayList<String> list = new ArrayList<>(); list.add("111"); list.add("222"); list.add("333"); log.info(list.toString()); for (String i : list) { i="444"; } log.info(list.toString());
Résultat :
12:34:47.207 [main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333]
12:34:47.211 [ main] INFO com.xiaolinge.com.hello.HelloWord - [111, 222, 333]
Tu vois, ça ne marche pas.
A quoi ça sert ? Il n'est pas possible de modifier l'élément, mais est-il possible de modifier l'attribut de l'élément ? Jetons un coup d'oeil.
(4) ForEach modifie les attributs des éléments
(car ne sera pas testé)
Créer une classe étudiante:
public class Student { private int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } private String name; public Student(){}; public Student(int age,String name){ this.age=age; this.name=name; } }
oh k, puis testez le code:
Student student=new Student(1,"huge"); Student student1=new Student(1,"xiaoyao"); List<Student> studentList=new ArrayList<Student>(); studentList.add(student); studentList.add(student1); System.out.println(student.getName()); System.out.println(student1.getName()); for(Student stu:studentList) { stu.setName("jingtian"); } System.out.println(student.getName()); System.out.println(student1.getName());
result:
huge
xiaoyao
jingtian
jingtian
484 est incroyable ! L'objet ne peut pas être modifié, mais les propriétés de l'objet peuvent être modifiées.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide de la racine carrée en Java. Nous discutons ici du fonctionnement de Square Root en Java avec un exemple et son implémentation de code respectivement.

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide du générateur de nombres aléatoires en Java. Nous discutons ici des fonctions en Java avec des exemples et de deux générateurs différents avec d'autres exemples.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.
