美文网首页Java
函数接口学习

函数接口学习

作者: 愤怒的老照 | 来源:发表于2020-05-21 17:40 被阅读0次

    1、Consumer,相当于消费者,接收一个参数但是不返回。在stream中的最终运算使用到。

    public interface Consumer<T> {
      // 消费一个数据
      void accept(T var1);
    
      // 链式调用,返回一个组合的Consumer,顺序执行
      default Consumer<T> andThen(Consumer<? super T> after) {
          Objects.requireNonNull(after);
          return (t) -> {
              this.accept(t);
              after.accept(t);
          };
      }
    }
    
    // accept方法使用,最后输出com www
    Consumer<String> consumer = System.out::println;
    ImmutableList.of("com","www").forEach(consumer);
    
    // andThen方法使用,多个Consumer形成链式调用,先向list中添加,然后打印
    Consumer<List<String>> consumer1 = list -> Collections.addAll(list,"com","www");;
    Consumer<List<String>> consumer2 = list -> list.forEach(System.out::println);
    consumer1.andThen(consumer2).accept(new ArrayList<>());
    

    补充:IntConsumer、DoubleConsumer、LongConsumer不需要使用泛型

    2、Supplier,相当于生产者,生产一个结果返回。stream的generate这类的函数有用到。

    public interface Supplier<T> {
        // 只有一个get方法,用于生产数据
        T get();
    }
    
    Supplier<Double> supplier = () -> Math.random();
    System.out.println(supplier.get());
    

    3、Predicate,预测,接收一个参数,判断并返回true或者false,经常用做过滤一些东西,比如Stream的filter。因为是true/false,所以有与或非逻辑。

    public interface Predicate<T> {
        // 判断返回true/false
        boolean test(T var1);
    
        // 接收一个Predicate,返回一个合并的Predicate,作用是&&
        default Predicate<T> and(Predicate<? super T> other) {
            Objects.requireNonNull(other);
            return (t) -> {
                return this.test(t) && other.test(t);
            };
        }
    
        // 取反
        default Predicate<T> negate() {
            return (t) -> {
                return !this.test(t);
            };
        }
        
        // 接收一个Predicate,返回一个合并的Predicate,作用是||
        default Predicate<T> or(Predicate<? super T> other) {
            Objects.requireNonNull(other);
            return (t) -> {
                return this.test(t) || other.test(t);
            };
        }
    }
    
    
    // 用作filter的判断
    Predicate<String> predicate = item->item.startsWith("www");
    
    ImmutableList.of("www","xxx","wwwccc","fff").stream().filter(predicate).collect(Collectors.toList());
    
    // 定义两个过滤条件,返回并集。这种需求之前遇到过,现在才知道有这种实现方式
     Predicate<String> predicate = item -> item.startsWith("www");
     Predicate<String> predicate1 = item -> item.length() == 3;
    System.out.println(ImmutableList.of("www", "xxx", "wwwccc", "fff").stream().filter(predicate.or(predicate1)).collect(Collectors.toList()));
        
    

    4、Function,接收一个参数T,返回一个参数F。stream的map中有用到

     // apply
     R apply(T var1);
    
       // 合并,可以实现链式调用,先执行参数
        default <V> Function<V, R> compose(Function<? super V, ? extends T> before) {
            Objects.requireNonNull(before);
            return (v) -> {
                return this.apply(before.apply(v));
            };
        }
    
        // 链式调用,先执行调用者
        default <V> Function<T, V> andThen(Function<? super R, ? extends V> after) {
            Objects.requireNonNull(after);
            return (t) -> {
                return after.apply(this.apply(t));
            };
        }
    
       // 返回本身,还是很有用的,可以用Function::identity代替it -> it;
        static <T> Function<T, T> identity() {
            return (t) -> {
                return t;
            };
        }
    
     // function 在map的用法
     Function<String, Integer> function = (str) -> Integer.parseInt(str);                
     ImmutableList.of("1","2","3").stream().map(function).collect(Collectors.toList());  
    
    // funciton 的链式调用,先转成int在+1
    Function<String, Integer> function = (str) -> Integer.parseInt(str);                                  
    Function<Integer, Integer> function1 = item -> item + 1;                                              
    ImmutableList.of("1","2","3").stream().map(function.andThen(function1)).collect(Collectors.toList()); 
    

    5、BiFunction,这是Function的增强版,Function只能接收一个参数,如果想要接收多个参数,可以使用BiFunction,与之类似的还有BiConsumer

    public interface BiFunction<T, U, R> {
        R apply(T var1, U var2);
    
        default <V> BiFunction<T, U, V> andThen(Function<? super R, ? extends V> after) {
            Objects.requireNonNull(after);
            return (t, u) -> {
                return after.apply(this.apply(t, u));
            };
        }
    }
    
    BiFunction<Integer, Integer, String> biFunction = (a, b) -> String.valueOf(a + b); 
    Function<String, String> function = (c) -> "Hello:" + c;                           
    

    一些方法用stream也可以处理的很好,而且可读性更强

    相关文章

      网友评论

        本文标题:函数接口学习

        本文链接:https://www.haomeiwen.com/subject/yictahtx.html