Maison > Java > javaDidacticiel > Comment exprimer la syntaxe de la dérivation fonctionnelle en Java8 Lamdba

Comment exprimer la syntaxe de la dérivation fonctionnelle en Java8 Lamdba

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Libérer: 2023-04-14 19:10:20
avant
1330 Les gens l'ont consulté

Avant-propos

L'interface avec une et une seule fonction abstraite est l'interface fonctionnelle. En utilisant l'interface fonctionnelle, nous pouvons créer lamdba, mais elle peut inclure des méthodes statiques et par défaut

1, la syntaxe de l'expression lamdba

Venons d'abord. Regardez l'application d'une simple expression lamdba, c'est-à-dire lors de la création d'un fil de discussion

        //创建一个线程,将线程的名字打印出来
        new Thread(()-
       System.out.println(Thread.currentThread().getName())).start();
        Thread.currentThread().join();
        //Thread-0
Copier après la connexion

Regardez l'exemple suivant :

        Comparator<Apple> byColor = new Comparator<Apple>() {
            @Override
            public int compare(Apple o1, Apple o2) {
                return o1.getColor().compareTo(o2.getColor());
            }
        };
        listApple.sort(byColor);
        Comparator<Apple> byCOlor2 = (o1,o2) -> o1.getColor().compareTo(o2.getColor());
Copier après la connexion

On voit facilement que la syntaxe de lamdba est composée comme suit :

paramètre + corps de fonction Tout comme o1 et o2 ci-dessus sont des paramètres, ce qui suit est le corps de fonction (Apple a) -> a.getColor() (paramètres) -> ; {instructions} 参数+函数体就像上面的o1 和o2就是参数,后面的就是函数体 (Apple a) -> a.getColor() (parameters)-> expression (parameters) ->{statements}

compareTo函数介绍:

 // 根据Unicode来判断,返回一个boolean 根据boolean来说明,这两个对象需不需要交换,其实我们可以不用这个CompareTo,我们可以自己写判断条件,只要是返回boolean就行
  public int compareTo(String anotherString) {
        int len1 = value.length;
        int len2 = anotherString.value.length;
        int lim = Math.min(len1, len2);
        char v1[] = value;
        char v2[] = anotherString.value;

        int k = 0;
        while (k < lim) {
            char c1 = v1[k];
            char c2 = v2[k];
            if (c1 != c2) {
                return c1 - c2;
            }
            k++;
        }
        return len1 - len2;
    }
Copier après la connexion

2,常见的函数式接口

  • Predicate boolean test(T t)

  • Consumer accept(T t)

  • Function R apple(T,t)

  • Supplier T get()

Predicate :传入一个变量返回一个Boolean值

private static List<Apple> filterApple(List<Apple> list, Predicate<Apple> predicate){
        List<Apple> lists = new ArrayList<>();
        for (Apple apple:list){
            if (predicate.test(apple)){
                lists.add(apple);
            }
        }
        return lists;
    }
//使用
        List<Apple> list = filterApple(listApple, apple -> apple.getWeight() > 100);
        System.out.println(list);
//我们发现在 filterApple 函数里面我们传入了两个参数,一个是list 一个是Predicate抽象函数式接口,我们调用这个抽象函数式接口,但是我们不实现它,我们在调用的时候实现它是根据重量来比较,当然我们在调用的时候也可以根据颜色来比较
/**
举一反三:Predicate是传入一个参数进行判断,BiPredicate是传入两个参数进行判断,例如下面的例子
*/

private static List<Apple> filterAppleByBiPredicaTe(List<Apple> apples, BiPredicate<String, Long> predicate){
List<Apple> lists = new ArrayList()
for(Apple apple:apples){
	if (predicate.test(apple.getColor(),apple.getWeight())){
			lists.add(apple)
	}
}
//从上面的例子上来看我们知道BiPredicate传入两个参数,根据颜色和重量来进行比较,我们在调用的时候可以实现者两个参数的比较规则
}
Copier après la connexion

Consumer 这个单词中文意思是消费者,既然消费了就不会有返回值

Fonction de comparaison Introduction:

private static void printlnApple(List<Apple> list, Consumer<Apple> consumer){
        if (list.size()>0){
            for (Apple apple:list){
                consumer.accept(apple);
            }
        }
    }
//使用
printlnApple(listApple,apple -> System.out.println(apple.getColor()));
/**
从上面我们可以看到 这个Consumer不会返回任何对象
举一反三: 上面有BiPredicate,那么我们这个Consumer有没有BiConsumer,答案肯定是有的,下面我们来看下BiConsumer的用法
*/
private static void printGreenAppleByBiConsumer(List<Apple> apples, Consumer<Apple, String> consumer){
	if(apples.size()>0){
		for(Apple apple:apples){
			consumer.accept(apple, apple.getColor())
		}
	}
}
//使用
printGreenAppleByBiConsumer(list,(apple, color)->{
	if(apple.getWeight()>100&&color.equal("green")){
		System.out.println(apple);
		}
})
//学习玩上面的例子 我再提一个 LongConsumer,从字面上看,我们知道,它接收的是一个Long类型的,其他的并没什么区别,这里我们就不多啰嗦了
Copier après la connexion

2, interface fonctionnelle commune

predicate Boolean test (t t)

  • Consumer accepter (t)

  • function & lt; t, r & gt ; R apple(T ,t)

Fournisseur T get()

Prédicat : Passer une variable et renvoyer une valeur booléenne

 private static Long getWeightList(Apple apple, Function<Apple,Long> function)
    {
        return function.apply(apple);
    }
//使用
  Long green = getWeightList(new Apple("green", 120), Apple::getWeight);
        System.out.println(green);
//在这里我们可以看到,Function函数的apply抽象方法接收一个值,返回一个Long类型的值

//根据上面的经验,想必大家也已经知道了还有 BiFunction 这个函数式接口,没错它只是传进去的参数有两个而已,还是返回一个结果。除此之外还有呢,大家别着急,还有  IntFunction DoubleFunction,这些有什么作用呢,其实可以看成是Function的具体情况  IntFuntion也就是  apply里面的参数是Int类型的 DoubleFunction也就是apply的参数是double类型的,大家再看一下,是不是非常非常的简单呢
Copier après la connexion

Le mot Consommateur en chinois signifie consommateur. est consommé, il n'y aura pas de valeur de retour🎜
    private static Apple  getApple(Supplier<Apple> supplier){
       return  supplier.get();
    }
    //使用
        Apple green1 = getApple(() -> new Apple("green", 150));
        System.out.println(green1);
   //有人肯定再想了,这样创建对象那不是脱裤子放屁吗 多此一举,这里只是举一个小例子,在实际开发中肯定不会这样
Copier après la connexion
🎜🎜Fonction : 🎜Fonction, nous savons que les fonctions ont toutes des sorties. Cela signifie qu'un paramètre est transmis et qu'un paramètre est renvoyé. à comment utiliser cette fonction🎜
    private static void printstr(Consumer<String> consumer, String str){
        consumer.accept(str);
    }
    //使用
        Consumer<String> consumer = a -> System.out.println(a);
        printstr(consumer,"hello world");
   //写成
   		Consumer<String> consumer = System.out::println
   		printstr(consumer,"hello world");
   //思考我们为什么可以写成这样呢,我们看下println的源码
       // public final static PrintStream out = null;,在源码里面我们可以看到PrintStream是一个静态的类,而println是这个静态类下面的方法,因此可以做函数推导
       public void println(String x) {
       //刚好是接收一个参数,没有返回
        synchronized (this) {
            print(x);
            newLine();
        }
    }

```再举个例子

```java
//将字符串转换成数字
int  value = Integer.parseInt("123")
 Function<String, Integer> stringFunction = Integer::parseInt;
 Integer result = stringFunction.apply("123");
 System.out.println(result)
 /**
 很多人看到这里就很纳闷了,怎么冒出一个 Function来了呢,这就是类方法推导,parseInt是Integer的类方法它需要传入一个数,然后输出一个数,这样的模式就是前面我们介绍的Function函数式接口,接着再来看一个例子
 */
 String string = new String("hello");
 Function<Integer, Character> f = string::charAt;
 Character c = f3.apply(4);
 System.out.println(c);
Copier après la connexion
🎜🎜Fournisseur : 🎜Ce mot signifie fournir, c'est-à-dire vous renvoyer des données. Cette interface de fonction vous renverra des données et ne vous obligera pas à transmettre des données🎜
Supplier<String> supplier = String::new
String s = supplier.get();
System.out.print(s)
//但是Apple是两个构造参数的,怎么办呢,还是有办法的
BiFunction<String, Long,Apple> appleFunction = Apple::new;
Apple apple = appleFunction.apply("red",100L);
//如果有更多的参数呢,在这里我们就可以自定义函数式接口
public interface CMyFuction<T,U,W,R>{
	R get(T t,U u, W w,R,r);
}
CMyFuction<String,String, Long> cmyfunction = Apple::new;
Apple apple =  cmyfunction.get("green","large",120);
//ok 这样自定义的函数式接口就完成了
Copier après la connexion
🎜3, dérivation fonctionnelle de l'expression Lamdba 🎜🎜🎜🎜1, utilisez la méthode statique d'une classe pour déduire 🎜🎜🎜🎜2, utilisez la méthode d'instance de l'objet pour déduire 🎜🎜🎜
//定义一个集合
  static List<Apple> listApple = Arrays.asList(
            new Apple("green",122),
            new Apple("red",  34),
            new Apple("black",135),
            new Apple("green",114),
            new Apple("yellow",54),
            new Apple("yellow",94));
 //以前我们排序的时候只知道调用 sort方法例如
 listAplle.sort()
 //但是我们不知道它怎么操作的,下面我们可以自定义排序的规则
 list.sort() //写道这里系统提示参数可以为Comparator,我们接着写
 list.sort(new Comparator<Apple>{
	public int compare(Apple o1, Apple o2){
		return o1.getColor().compareTo(o2.getColor());
	}
})
 //从上面的里例子来看我们是根据apple的颜色来进行比较的,当然我们也可以根据apple的weight来进行比较.接着我们进行函数推导
 list.sort(Comparator.comparing(Apple::getColor))
 //就这么一句完全代替了我们上面的功能,很明显简化了代码
Copier après la connexion
🎜🎜Dérivation du constructeur 🎜🎜rrreee🎜🎜Examp : le : 🎜Classification des tris et expression fonctionnelle Dérivation 🎜rrreee

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!

Étiquettes associées:
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers numéros
Impossible d'installer Java
Depuis 1970-01-01 08:00:00
0
0
0
Java peut-il être utilisé comme backend du Web ?
Depuis 1970-01-01 08:00:00
0
0
0
Installer JAVA
Depuis 1970-01-01 08:00:00
0
0
0
Aide : Données chiffrées JAVA Décryptage PHP
Depuis 1970-01-01 08:00:00
0
0
0
Est-ce en langage Java ?
Depuis 1970-01-01 08:00:00
0
0
0
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal