Il ne fait aucun doute que l'occasion la plus couramment utilisée pour les expressions lambda est de remplacer des classes internes anonymes, et l'implémentation de l'interface Runnable est un exemple classique de classes internes anonymes. Les expressions Lambda sont assez puissantes. Vous pouvez utiliser ()-> pour remplacer toute la classe interne anonyme ! Veuillez regarder le code :
Si vous utilisez une classe interne anonyme :
@Test public void oldRunable() { new Thread(new Runnable() { @Override public void run() { System.out.println("The old runable now is using!"); } }).start(); }
Et si vous utilisez une expression lambda :
@Test public void runable() { new Thread(() -> System.out.println("It's a lambda function!")).start(); }
La sortie finale :
L'ancien runable utilise maintenant !
C'est une fonction lambda !
Oui N'est-ce pas terriblement puissant ? Est-ce terriblement simple ? Est-ce terriblement clair et ciblé ? C'est ce qui fait peur avec les expressions lambda. Elles utilisent très peu de code pour accomplir ce que la classe précédente a fait !
Les classes de collection Java sont souvent utilisées dans le développement quotidien, et on dit même qu'il n'y a pas de code Java qui n'utilise pas de classes de collection. . . L’opération la plus courante sur les classes de collection est le parcours itératif. Veuillez consulter la comparaison :
@Test public void iterTest() { List<String> languages = Arrays.asList("java","scala","python"); //before java8 for(String each:languages) { System.out.println(each); } //after java8 languages.forEach(x -> System.out.println(x)); languages.forEach(System.out::println); }
Si vous connaissez scala, vous devez connaître forEach. Il parcourt tous les objets de la collection et y introduit des expressions lambda.
languages.forEach(System.out::println);
Cette ligne ressemble un peu à la façon dont la résolution de portée est écrite en C++, et c'est également possible ici.
Quand il s'agit de programmation fonctionnelle et d'expressions lambda, comment ne pas mentionner map. . . Oui, Java8 est définitivement pris en charge. Veuillez consulter l'exemple de code :
@Test public void mapTest() { List<Double> cost = Arrays.asList(10.0, 20.0,30.0); cost.stream().map(x -> x + x*0.05).forEach(x -> System.out.println(x)); }
Le résultat final :
10.5
21.0
31.5
La fonction map peut être considérée comme la méthode la plus importante dans la programmation fonctionnelle. La fonction de la carte est de transformer un objet en un autre. Dans notre exemple, le coût est augmenté de 0,05 fois la taille grâce à la méthode cartographique, puis à la sortie.
Puisque map est mentionné, comment pouvons-nous ne pas mentionner réduire. Comme map, la réduction est également l’une des méthodes les plus importantes en programmation fonctionnelle. . . La fonction de map est de changer un objet en un autre, tandis que la fonction de reduction est de fusionner toutes les valeurs en une seule. Veuillez voir :
@Test public void mapReduceTest() { List<Double> cost = Arrays.asList(10.0, 20.0,30.0); double allCost = cost.stream().map(x -> x+x*0.05).reduce((sum,x) -> sum + x).get(); System.out.println(allCost); }
Le résultat final est :
63.0
Si nous utilisons un for. boucle pour le faire Cette question :
@Test public void sumTest() { List<Double> cost = Arrays.asList(10.0, 20.0,30.0); double sum = 0; for(double each:cost) { each += each * 0.05; sum += each; } System.out.println(sum); }
Je crois que la façon d'écrire l'expression map+reduce+lambda est plus d'un niveau plus haut.
le filtre est aussi une opération que nous utilisons souvent. Lors de l’exploitation d’une collection, il est souvent nécessaire de filtrer certains éléments de la collection originale.
@Test public void filterTest() { List<Double> cost = Arrays.asList(10.0, 20.0,30.0,40.0); List<Double> filteredCost = cost.stream().filter(x -> x > 25.0).collect(Collectors.toList()); filteredCost.forEach(x -> System.out.println(x)); }
Le résultat final :
Avez-vous envie d'écrire du java en python ou en scala ! N'est-il pas si beau ? 6. Coopérer avec l'interface fonctionnelle PredicateEn plus de prendre en charge le style de programmation fonctionnelle au niveau du langage, Java 8 a également ajouté un package appelé java.util.function. Il contient de nombreuses classes pour prendre en charge la programmation fonctionnelle en Java. L'un d'eux est Predicate. En utilisant l'interface fonctionnelle java.util.function.Predicate et les expressions lambda, vous pouvez ajouter une logique aux méthodes API et prendre en charge des comportements plus dynamiques avec moins de code. L'interface Predicate est très adaptée au filtrage.
30.0
30.0
40.0
40.0
public static void filterTest(List<String> languages, Predicate<String> condition) { languages.stream().filter(x -> condition.test(x)).forEach(x -> System.out.println(x + " ")); } public static void main(String[] args) { List<String> languages = Arrays.asList("Java","Python","scala","Shell","R"); System.out.println("Language starts with J: "); filterTest(languages,x -> x.startsWith("J")); System.out.println("\nLanguage ends with a: "); filterTest(languages,x -> x.endsWith("a")); System.out.println("\nAll languages: "); filterTest(languages,x -> true); System.out.println("\nNo languages: "); filterTest(languages,x -> false); System.out.println("\nLanguage length bigger three: "); filterTest(languages,x -> x.length() > 4); }
Comme vous pouvez le voir, la méthode de filtrage de l'API Stream accepte également un prédicat, ce qui signifie que notre méthode filter() personnalisée peut être remplacée par le code en ligne écrit à l'intérieur , c'est aussi la magie des expressions lambda. 🎜Java
Le langage commence par J :scala
Le langage se termine par un :
JavaR
Toutes les langues :
Java
Python
scala
ShellAucune langue :
Shell
Longueur du langage trois plus grandes :
Python
scala
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!