Input/Output e Stream in Java
Alex Liu
Software Development Engineer
HashSet di esempio per il resto del videoimport java.util.HashSet;public class SampleHashSetData { public static void main(String[] args) { HashSet<String> fruits = new HashSet<>();fruits.add("Apple"); fruits.add("Banana");} }
{Apple, Banana}
For-Each loopfor (type x: collection){}List, Set, Map e altrofruits: [Apple, Banana].for (String x : fruits) {
System.out.println(x);
}
Apple
Banana
Iterator<>: supporta List, Set, Queue e altroIteratorimport java.util.Iterator;// Crea l'oggetto `Iterator` chiamato `it` per il set `fruits` Iterator<String> it = fruits.iterator(); // Il metodo `.hasNext()` verifica se ci sono altri elementi while (it.hasNext()) { // `.next()` recupera l'elemento System.out.print(it.next());}
Apple Banana
.remove() per rimuovere con Iterator$$
Iterator<String> it = fruits.iterator();
while (it.hasNext()) {
String fruit = it.next();
if (fruit.startsWith("A")) {
// Rimuovi se l'elemento inizia con `A`
it.remove();
}
}
// fruits ora contiene solo "Banana"
Prima della rimozione:
System.out.println(fruits);
[Apple, Banana]
Dopo la rimozione:
System.out.println(fruits);
[Banana]
Garantisce eliminazione sicura ed evita ConcurrentModificationException

for-eachList(ArrayList,LinkedList)Set(HashSet,TreeSet,LinkedHashSet)Queue(PriorityQueue)Stack(Stack)MapRimozione di elementiIteratorList(ArrayList,LinkedList)Set(HashSet,TreeSet,LinkedHashSet)Queue(PriorityQueue)Stack(Stack)Map (usa keySet().iterator, values().iterator o entrySet().iterator)Rimozione di elementiInput/Output e Stream in Java