标签:员工 setter getter col 分享 source order 避免 iterable
JDK预定义了很多函数接口以避免用户重复定义。最典型的是Function:
@FunctionalInterface public interface Function<T, R> { R apply(T t); }
这个接口代表一个函数,接受一个T类型的参数,并返回一个R类型的返回值。
另一个预定义函数接口叫做Consumer,跟Function的唯一不同是它没有返回值。
@FunctionalInterface public interface Consumer<T> { void accept(T t); }
还有一个Predicate,用来判断某项条件是否满足。经常用来进行筛滤操作:
@FunctionalInterface public interface Predicate<T> { boolean test(T t); }
综上所述,一个λ表达式其实就是定义了一个匿名方法,只不过这个方法必须符合至少一个函数接口。
public class Emp { private int empno; private String ename; //getter|setter|toString略 public static void printEmp(Emp emp){ System.out.println("empno:"+emp.getEmpno()+"\nename:"+emp.getEname()); } }
static List<Emp> emps = Arrays.asList( new Emp(1, "yw"), new Emp(2, "yt"), new Emp(3, "yp"), new Emp(4, "yc"));
@Test public void testPredicate() { Predicate<Emp> predicate = emp -> emp.getEmpno()>1; for(Emp e:emps) { if(predicate.test(e)) { Emp.printEmp(e); } } }
@Test public void testFunction() { //抽取员工的名称 Function<Emp,String> function = emp -> emp.getEname(); for (Emp emp : emps) { String ename = function.apply(emp); System.out.println(ename); } }
@Test public void testConsumer() { Consumer<Emp> consumer = Emp::printEmp; for(Emp e:emps) { consumer.accept(e); } }
private <T,R> void printEmpNameWhenEmpNoLg1(Iterable<T> source,Predicate<T> predicate,Function<T,R> function, Consumer<R> consumer) { for(T t:source) { if(predicate.test(t)) { R r = function.apply(t); consumer.accept(r); } } }
此函数包含四个参数,分别为实现了Iterable接口的List(此例中即emps)及三个预定义函数接口。应用如下:
@Test public void testFunctionInterface() { Predicate<Emp> predicate = emp -> emp.getEmpno()>1; Function<Emp,String> function = emp -> emp.getEname(); Consumer<String> consumer = System.out::println; printEmpNameWhenEmpNoLg1(emps,predicate,function,consumer); }
标签:员工 setter getter col 分享 source order 避免 iterable
原文地址:http://www.cnblogs.com/vvning/p/7657268.html