java8函数式接口

简介: java8函数式接口使用及lambda使用

常见的函数式接口

Consumer消费接口:在方法中传入参数进行消费 void accept(T t)

Function计算转换接口:可以在方法中对传入的参数进行计算或转换,把结果返回 R apply(T t)

Predicate判断接口:可以在方法中传入参数条件,返回判断结果boolean test(T t)

Supplier生产型接口:可以在方法中创建对象,把创建好的对象返回T get()


Consumer:传入一个参数,并对其进行相应的操作

public static void main(String[] args) {

   List<String> list = new ArrayList();
   list.add("qqq");
   list.add("aaa");
   // 1.直接创建接口
   Consumer<String> consumer1 = new Consumer<String>() {

       @Override
       public void accept(String s) {

           System.out.println(s);
       }

   };
   // 直接使用consumer
   list.stream().forEach(consumer1);

   // 2.lambda表达式使用
   Consumer<String> consumer2 = System.out::println;
   list.stream().forEach(consumer2);
}


Supplier:可以传入数据,作为一个容器

Supplier可以简单的视为就是一个存放指定类型的容器,需要时再取出来:

public static void testSupplier(){

   //1.直接创建
   Supplier<String> supplier = new Supplier<String>() {

       @Override
       public String get() {

           return "this is supplier";
       }

   };
   System.out.println(supplier.get());

   //2.lambda
   Supplier<String> supplier1 = () -> "this is supplier";
   System.out.println(supplier1.get());
}


Function: 主要是用作数据类型之间的转换

Function的抽象方法只有一个apply,即对传入的参数进行处理并返回,其他的都是辅助方法:

//1apply 示例
private static void applyTest() {

   //示例1:利用lambda方式实现一个funciton,String转换为Integer
   Function<String,User> function = new Function<String, User>() {

       @Override
       public User apply(String s) {

           User user = new User();
           user.setName(s);
           return user;
       }

   };
   User tom = function.apply("tom");
   System.out.println(tom);

   Function<String, Integer> function1 = x -> Integer.parseInt(x);
   Integer a = function1.apply("100");
   System.out.println(a.getClass());
}


compose:组合函数,调用当前function之前调用

andThen:组合函数,调用当前function之后调用

identity:静态方法,返回与原函数参数一致的结果。x=y


//2andThen 示例——实现一个函数 y=10x + 10;
   private static void andThenTest() {

       //先执行 10 * x
       Function<Integer, Integer> function2 = x -> 10 * x;
       //通过andThen在执行 这里的x就等于上面的10 * x的值
       function2 = function2.andThen(x -> x + 10);
       System.out.println(function2.apply(2));
   }


   //3compose 示例-实现一个函数 y=(10+x)2
   private static void composeTest() {

       Function<Integer, Integer> function3 = x -> x * 2;
       //先执行 x+10 在执行(x+10)*2顺序与上面相反
       function3 = function3.compose(x -> x + 10);
       System.out.println(function3.apply(3));
   }


   //4、综合示例
//使用compose()andThen()实现一个函数 y=(10+x)*2+10;
   private static void test() {

       //真正执行的第二步
       Function<Integer, Integer> function4 = x -> x * 2;
       //真正执行的第一步
       function4 = function4.compose(x -> x + 10);
       //真正执行的第三步
       function4 = function4.andThen(x -> x + 10);
       System.out.println(function4.apply(3));
   }


Predicate:传入参数,而后返回判断的结果true/false

   public static void testPredicate(){

       //1.直接创建
       Predicate<String> predicate = new Predicate<String>() {

           @Override
           public boolean test(String s) {

               if ("test".equals(s)) {

                   return true;
               }

               return false;
           }

       };
       System.out.println(predicate.test("test"));

       // 2.lambda
       Predicate<String> predicate1 = "test"::equals;
       predicate1.test("test");
   }

相关文章
|
1天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
14 6
|
1天前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
【10月更文挑战第16天】Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。通过 hashCode() 和 equals() 方法实现唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 添加和遍历元素,体现了 Set 的高效性和简洁性。
11 4
|
3天前
|
存储 Java 数据处理
Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。
Java Set:无序之美,不重复之魅!Set 是 Java 集合框架中的一个接口,不包含重复元素且不保证元素顺序。它通过 hashCode() 和 equals() 方法确保元素唯一性,适用于需要唯一性约束的数据处理。示例代码展示了如何使用 HashSet 实现这一特性。
12 5
|
1天前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
7 2
|
3天前
|
存储 Java 数据处理
在Java集合框架中,Set接口以其独特的“不重复”特性脱颖而出
【10月更文挑战第14天】在Java集合框架中,Set接口以其独特的“不重复”特性脱颖而出。本文通过两个案例展示了Set的实用性和高效性:快速去重和高效查找。通过将列表转换为HashSet,可以轻松实现去重;而Set的contains方法则提供了快速的元素查找功能。这些特性使Set成为处理大量数据时的利器。
12 4
|
3天前
|
Java
Java Set 是一个不包含重复元素的集合接口,确保每个元素在集合中都是唯一的
【10月更文挑战第14天】Java Set 是一个不包含重复元素的集合接口,确保每个元素在集合中都是唯一的。本文介绍了 Set 的独特特性和两个常用实现类:基于哈希表的 HashSet 和基于红黑树的 TreeSet。通过示例代码展示了它们如何高效地处理唯一性约束的数据。
15 3
|
3天前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其独特的“不重复性”要求,彻底改变了处理唯一性约束数据的方式。
【10月更文挑战第14天】从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其独特的“不重复性”要求,彻底改变了处理唯一性约束数据的方式。本文深入探讨Set的核心理念,并通过示例代码展示了HashSet和TreeSet的特点和应用场景。
9 2
|
3天前
|
存储 Java 索引
Java 中集合框架的常见接口和类
【10月更文挑战第13天】这些只是集合框架中的一部分常见接口和类,还有其他一些如 Queue、Deque 等接口以及相关的实现类。理解和掌握这些集合的特点和用法对于高效编程非常重要。
|
4天前
|
存储 Java 数据处理
Java中的Set接口以其独特的“不重复”特性,在集合框架中占据重要地位。
【10月更文挑战第13天】Java中的Set接口以其独特的“不重复”特性,在集合框架中占据重要地位。本文通过两个案例展示了Set的实用性和高效性:快速去重和高效查找。通过将列表转换为HashSet,可以轻松实现去重;而Set的contains方法则提供了高效的元素查找功能。这些特性使Set在处理大量数据时表现出色,值得我们在日常编程中充分利用。
17 3
|
8天前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
14 1