拉姆达表达式、Stream

Q:最近接触到Stream流式编程遇到了一些错误,故做一次总结复习用。

一、λ表达式

通常我们会用一个类实现接口,然后构造对象作为参数传入,也可以使用匿名类,用λ表达式可以简化匿名类的编写,用例如下。

        class Worker implements Runnable {
        @Override
            public void run() {
            // TODO: 2019/6/2
            }
       }
        Thread t = new Thread(new Runnable() {
            @Override
            public void run() {
                // TODO: 2019/6/2
            }
        });
        Thread t1 = new Thread(new Worker());
        
        Thread t2 = new Thread(()->{
            // TODO: 2019/6/2
        });
λ表达式语法:
(String str,...)->{      }
 ()->{}
 ()-> System.out.println();
 表达式中引用的外部的变量,必须是   最终变量  final
 List<Integer> list = new LinkedList<>();
 list.forEach(System.out::println);//这里是类的静态方法,也可以是Object::instanceMethod,也可以是Class::instanceMethod
                                                                                        //  System.out::println== x->sout(x)      Math::pow == Math.pow(x,y)
也可以是  Class::new
        List<String> list = Arrays.asList("zhangsan","lisi");
        List<Person> res=  list.stream().map(Person::new).collect(Collectors.toList());
        System.out.println(res);
          //   [zhangsan, lisi]
 list.forEach(e-> System.out.println(e)); //只有一行可以省略花括号
Comparator<String> c =(f,fs)->f.length-fs.length;    //可推导出f  fs 必然是字符串等价于(String f, String  fs)则可以省略方法参数的类型
其中Comparator如下:
public interface Comparator<T> {
    int compare(T o1, T o2);
}




函数式接口
public static <T> void sort(T[] a, Comparator<? super T> c)
Integer[] array = new Integer[]{3,2,1};
Arrays.sort(array,(o1, o2) -> o1-o2);
//sout   1,2,3

@FunctionalInterface
public interface BiFunction<T, U, R>{ 
    R apply(T t, U u)   //输入T、U  返回  R类型
    default <V> BiFunction<T, U, V> andThen(Function<? super R, ? extends V> after) {
        Objects.requireNonNull(after);                   //输入T、U  返回  R类型 
        return (T t, U u) -> after.apply(apply(t, u)); //然后将R传入作为参数传入Function<? super R, ? extends V> after
    };                                                                    //对于Function而言,传入值为V的子类,返回值是R的一种父类
}

@FunctionalInterface
public interface Function<T, R> {
    R apply(T t);
    default <V> Function<V, R> compose(Function<? super V, ? extends T> before) { 
        Objects.requireNonNull(before);
        return (V v) -> apply(before.apply(v));
    }
    default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
        Objects.requireNonNull(after);
        return (T t) -> after.apply(apply(t));
    }
    static <T> Function<T, T> identity() {
        return t -> t;
    }
}

常见函数式接口:
在这里插入图片描述
在这里插入图片描述

Stream 解析

stream of elements -----> filter ->sorted->  map ->  collect

其中  Stream<T> filter(Predicate<? super T> predicate);       返回值为Stream
@FunctionalInterface
public interface Predicate<T> {
    boolean test(T t) ;             //校验是否满足条件
    default Predicate<T> and(Predicate<? super T> other) { //且
        Objects.requireNonNull(other);
        return (t) -> test(t) && other.test(t);
    }
    default Predicate<T> negate() {//校验是否不满足条件
        return (t) -> !test(t);
    }
    default Predicate<T> or(Predicate<? super T> other) {
        Objects.requireNonNull(other);
        return (t) -> test(t) || other.test(t);
    }
    static <T> Predicate<T> isEqual(Object targetRef) {
        return (null == targetRef)
                ? Objects::isNull
                : object -> targetRef.equals(object);
    }
}

//sorted
Stream<T> sorted();   //元素自身需要实现  Comparable
Stream<T> sorted(Comparator<? super T> comparator);

// map  将集合中的元素转换为另外一种类型 ,同时返回的为  Stream
<R> Stream<R> map(Function<? super T, ? extends R> mapper);
@FunctionalInterface
public interface Function<T, R> {
    R apply(T t);
}


----------------------------------------------------#### //reduce
   Optional<T> reduce(BinaryOperator<T> accumulator);//流的第一个元素与第二个进行操作返回相同类型作为第一个参数再次传入
                               //如(x,y)->x+u  流为:1,2,3,...    则(1,2)->3     (3,3)->6   .......
    public interface BinaryOperator<T> extends BiFunction<T,T,T> {  //BiFunction<T,T,T>      T apply(T t, T u);
        public static <T> BinaryOperator<T> minBy(Comparator<? super T> comparator) {
        Objects.requireNonNull(comparator);
        return (a, b) -> comparator.compare(a, b) <= 0 ? a : b;
        }
        public static <T> BinaryOperator<T> maxBy(Comparator<? super T> comparator) {
        Objects.requireNonNull(comparator);
        return (a, b) -> comparator.compare(a, b) >= 0 ? a : b;
        }
    }
//用法 
        List<Integer> list = Arrays.asList(3, 2, 4, 1, 5, 6, 7); ///10
        System.out.println(list.stream().reduce((a, b) -> a+ b).get()); //求和     T apply(T t, T u);
        
        List<String> list = Arrays.asList("zhangsan","lisi","wangwu");  //拼接 
        System.out.println(list.stream().filter(e->e.length()>1)
                .reduce((s, s2) -> s+","+s2).get());
 BinaryOperator<Integer> bi = BinaryOperator.minBy(Comparator.naturalOrder());
      System.out.println(bi.apply(2, 3));  //sout    2
--------------------------------------------------
      T reduce(T identity, BinaryOperator<T> accumulator);//这里同上,只是给出了一个初始值 
 



      <U> U reduce(U identity,BiFunction<U, ? super T, U> accumulator,BinaryOperator<U> combiner);  //BiFunction<T, U, R>
      //这里U可以是不同类型,例如 是一个容器,可以存放流中处理的值
//第二个表达式中 输入为 T,U返回值为U 即该方法第一个参数会作为参数传入,第三个参数只有在并行的时候才有用,合并结果集
        list.stream().reduce(new ArrayList<Integer>(), new BiFunction<ArrayList<Integer>, Integer, ArrayList<Integer>>() {
            @Override
            public ArrayList<Integer> apply(ArrayList<Integer> integers, Integer integer) {
                integers.add(integer);
                return integers;
            }
        }, new BinaryOperator<ArrayList<Integer>>() {
            @Override
            public ArrayList<Integer> apply(ArrayList<Integer> strings, ArrayList<Integer> strings2) {
                return strings;
            }
        });


----------------------------------------------------------
collect
    <R, A> R collect(Collector<? super T, A, R> collector);



    <R> R collect(Supplier<R> supplier,
                  BiConsumer<R, ? super T> accumulator,
                  BiConsumer<R, R> combiner);











發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章