lambda表达式实用实例

java8新特性lambda的使用

//最基本的遍历方法
List<User> users = Lists.newArrayList();
        users.add(new User("1", "张三"));
        users.add(new User("2", "李四"));
	//一般遍历方式
	for (User user : users) {
            System.out.println(user.toString());
        }
    //采用lambda来遍历List集合
	users.forEach(System.out::println);

流的中间操作筛选和切片
//filter:过滤元素中的某些数据
//limit(n):获取第n个元素
// skip(n):跳过n元素,配合limit可实现分页
// distinct:通过流元素中的hashCode() 和 equals来去重

List<Integer> streamMid = Arrays.asList(1, 2, 5, 5, 6, 7, 9);
        //筛选数值大于5的数据
        streamMid.stream().filter(c -> c > 5).collect(Collectors.toList());
        //获取前两个元素
        streamMid.stream().limit(2);
        //跳过前二个元素
        streamMid.stream().skip(2);
        //过滤小于10的元素,在去重,在跳过前两个元素,获取第2个元素
        streamMid.stream().filter(c -> c <        
        10).distinct().skip(2).limit(2);
        public static void main(String[] args) {
        List<Student> students = Lists.newArrayList();
        students.add(new Student("张三", 10));
        students.add(new Student("李四", 20));
        students.add(new Student("李四", 42));
        students.add(new Student("王五", 30));
      
        List<String> mapList = Arrays.asList("a,b,c", "1,2,3");
        //去除当前list中的,和空格 转成一个新的元素 sout abc 123
        Stream<String> stringStream = mapList.stream().map(s -> s.replace(",", ""));
        /**
         * 知识点 流的中间操作筛选和切片中filter过滤元素中的某些数据
         * 获取年龄为30岁并且第一个字是王的(startsWith获取开头的数据)
         */

        List<Student> collectName = students.stream().filter(c -> c.getAge() == 30 && c.getName().startsWith("王")).collect(Collectors.toList());
        System.out.println("-----------------获取年龄为30岁并且第一个字是王的"+collectName);
        /**
         * 知识点map,distinct
         * 根据名字去重
         */
        students.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(
                () -> new TreeSet<>(Comparator.comparing(Student::getName))
        ), ArrayList::new)).forEach(System.out::println);

        /**
         * 知识点sorted
         * 根据年龄进行升序排列
         *流的中间操作排序(sort)
         */
        students.sort(Comparator.comparing(Student::getAge));
        System.out.println("-------------------------------------根据年龄进行升序排列"+students);
    }
        List<Student> students = Lists.newArrayList();
        students.add(new Student("aa", 10));
        students.add(new Student("bb", 20));
        students.add(new Student("aa", 30));
        students.add(new Student("dd", 40));
     //先根据姓名进行升序姓名相同年龄升序(thenComparing然后根据什么排序的意思)
	  students.sort(Comparator.comparing(Student::getName).thenComparing(Student::getAge)).;
	 //String类型是可以直接进行排序的 因为它本身就实现了Comparable接口
	 List<String> strings = Arrays.asList("dd", "aa", "ff");
	  strings.stream().sorted();
/**
         * 冒泡排序
         *      比较相邻元素,第一个大于第二个就进行交换
         *      一直到最后一个为最大数
         *      针对所有的元素执行以上操作,除了最后一个 故而用length-1
         *      第一次是对第n个数进行n-1 进行到最后一个n是最大的
         *      第二次是对第n-1个数进行n-2次比较,进行到最后一个第n-1次是最大的
         *       for (int i = 0; i < num.length - 1; i++) {
         *             for (int j = 0; j < num.length - 1 - i; j++) {
         *                 if (num[j] > num[j + 1]) {
         *                     int temp = num[j];
         *                     num[j] = num[j + 1];
         *                     num[j + 1] = temp;
         *                 }
         *             }
         *         }
         *                 Integer[] num = new Integer[]{1, 5, 8, 2, 9, 7};
         */
List<User> users = Lists.newArrayList();
        users.add(new User("1", "张三"));
        users.add(new User("2", "李四"));
        users.add(new User("0", "王五"));

//过滤id为1的和名字为张三的User并转成List
 List<User> collect = users.stream().filter(c -> c.getId().equals("1")&&c.getName().equals("张三")).collect(Collectors.toList());

//过滤id为1的User并转成List
 List<User> collect = users.stream().filter(c -> c.getId().equals("1")).collect(Collectors.toList());

//对当前list进行去重
distinct.collect(Collectors.toList()).forEach(c->{
            System.out.println(c.toString());
});

Optional<User> first = users.stream().findFirst();//获取当前list中的第一个对象


for (Trader trader:traders) { };类似  traders.forEach(c->{System.out.println(); });

filter里面要跟一个boolean表达式
.var 有返回值的用这个都可以自动生成对象
获取演员名字为3个字的三个人 
 ArrayList<String> manArray = new ArrayList<>();
        manArray.add("刘德华");
        manArray.add("成龙");
        manArray.add("吴彦祖");
        manArray.add("周润发");
        manArray.add("周星驰");
        manArray.add("吴京");
 s.length就是当前这个字符串的长度==3  然后limit就是和sql的差不多

manArray.stream().filter(s -> s.length() == 3).limit(3).collect(Collectors.toList()).forEach(System.out::println);



 List<Trader> traders = Lists.newArrayList();
        traders.add(new Trader(1, "赵六", new Date()));
        traders.add(new Trader(2, "王五", new Date()));
        traders.add(new Trader(3, "李四", new Date()));
        traders.add(new Trader(4, "张三", new Date()));
        traders.add(new Trader(5, "张三", new Date()));

List<Integer> collect = traders.stream().map(Trader::getId).collect(Collectors.toList());
System.out.println("==============获取id列表");

traders.stream().filter(c -> c.getName().equals("张三")).forEach(System.out::println);
System.out.println("==============获取name=张三的 数据");

traders.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(Trader::getName))), ArrayList::new)).forEach(System.out::println);
System.out.println("==============去除名字相同的数据");

traders.stream().filter(c -> c.getId() > 1).collect(Collectors.toList()).forEach(System.out::println);
System.out.println("==============获取id>1的数据,并转为集合");

待续。。