Kullanılması lambdas ve fonksiyonel arayüzler de Java 8 olası yeni döngü soyutlamalar oluşturarak yapar. Ben dizin ve koleksiyon boyutu ile bir koleksiyon üzerinde döngü olabilir:
List<String> strings = Arrays.asList("one", "two","three","four");
forEach(strings, (x, i, n) -> System.out.println("" + (i+1) + "/"+n+": " + x));
Hangi çıktılar:
1/4: one
2/4: two
3/4: three
4/4: four
Hangi olarak uyguladı:
@FunctionalInterface
public interface LoopWithIndexAndSizeConsumer<T> {
void accept(T t, int i, int n);
}
public static <T> void forEach(Collection<T> collection,
LoopWithIndexAndSizeConsumer<T> consumer) {
int index = 0;
for (T object : collection){
consumer.accept(object, index++, collection.size());
}
}
İmkanlar sonsuzdur. Örneğin, yalnızca ilk öğe için özel bir işlev kullanan bir soyutlama oluşturuyorum:
forEachHeadTail(strings,
(head) -> System.out.print(head),
(tail) -> System.out.print(","+tail));
Hangi virgülle ayrılmış listeyi doğru yazdırır:
one,two,three,four
Hangi olarak uyguladı:
public static <T> void forEachHeadTail(Collection<T> collection,
Consumer<T> headFunc,
Consumer<T> tailFunc) {
int index = 0;
for (T object : collection){
if (index++ == 0){
headFunc.accept(object);
}
else{
tailFunc.accept(object);
}
}
}
Kütüphaneler bu tür şeyleri yapmak için açılmaya başlayacak ya da kendinizinkini oluşturabilirsiniz.
Type var = null; for (var : set) dosomething; if (var != null) then ...