zoukankan      html  css  js  c++  java
  • JDK 集合 LIST

    一、继承关系图

    二、类图

            java中的List接口以及实现类,类图如下:

    * @author  Josh Bloch
     * @author  Neal Gafter
     * @see Collection
     * @see Set
     * @see ArrayList
     * @see LinkedList
     * @see Vector
     * @see Arrays#asList(Object[])
     * @see Collections#nCopies(int, Object)
     * @see Collections#EMPTY_LIST
     * @see AbstractList
     * @see AbstractSequentialList
     * @since 1.2

    三、源码分析

    public interface List<E> extends Collection<E> {
    
      /**
      * 定义addAll方法,从某个index开始插入指定集合实例
      */
      boolean addAll(int index, Collection<? extends E> c);
    
      /**
      * 定义removeAll方法,从某个index开始删除指定集合实例
      */
      boolean removeAll(Collection<?> c);
    
      /**
      * 定义removeAll方法,从某个index开始删除指定集合实例
      */
      boolean retainAll(Collection<?> c);
    
      /**
      * jdk1.8新增
      * 大意为:
      * 定义replaceAll方法,根据传递参数的函数式,传递内容是接口类型
      * 该接口定义了operator函数,该函数传递给Objects.requireNonNull进行判断
      * 匹配成功则进行set值进行替换,使用List迭代器进行迭代替换
      * @since 1.8
      */
      default void replaceAll(UnaryOperator<E> operator) {
        Objects.requireNonNull(operator);
        final ListIterator<E> li = this.listIterator();
        while (li.hasNext()) {
        li.set(operator.apply(li.next()));
        }
      }
    
      /**
      * jdk1.8新增
      * 大意为:
      * 定义sort方法,根据传递参数的函数式,传递内容是接口类型
      * 该接口定义了Comparator函数,该函数传递给Arrays.sort进行判断并排序
    
      * 并根据排序结果,使用迭代器迭代并重新set进List
      * @since 1.8
      */
      @SuppressWarnings({"unchecked", "rawtypes"})
      default void sort(Comparator<? super E> c) {
        Object[] a = this.toArray();
        Arrays.sort(a, (Comparator) c);
        ListIterator<E> i = this.listIterator();
        for (Object e : a) {
          i.next();
          i.set((E) e);
        }
      }
    
      /**
      * List要求,定义get方法,获取指定index的值
      */
      E get(int index);
    
      /**
      * List要求,定义set方法,在指定index的元素设置为目标元素
      */
      E set(int index, E element);
    
      /**
      * List要求,定义add方法,在指定index添加指定元素
      */
      void add(int index, E element);
    
      /**
      * List要求,定义remove方法,从指定的index删除该元素并重新调整List
      */
      E remove(int index);
    
      /**
      * List要求,定义indexOf方法,正序查询指定元素第一次出现的index序号
      */
      int indexOf(Object o);
    
      /**
      * List要求,定义lastIndexOf方法,倒叙查询指定元素第一次出现的的index序号
      */
      int lastIndexOf(Object o);
    
      /**
      * List要求,定义ListIterator迭代器方法,获取该List的迭代器
      */
      ListIterator<E> listIterator();
    
      /**
      * List要求,定义ListIterator迭代器方法,获取从指定index开始的指定迭代器
      */
      ListIterator<E> listIterator(int index);
    
      /**
      * List要求,定义subList方法,从起始和结束index拆分出新的list
      */
      List<E> subList(int fromIndex, int toIndex);
    
      /**
      * jdk1.8新增
      * 大意为:
      * 根据当前的list内容进行排序,进行迭代器拆分,拆分成新的迭代器
      * 用于多线程迭代使用
      * @since 1.8
      */
      @Override
      default Spliterator<E> spliterator() {
        return Spliterators.spliterator(this, Spliterator.ORDERED);
      }

    四、JDK8对list的流处理

    1. 跟据某个属性分组OfficeId:

     Map<String, List<IncomeSumPojo>> collect = list.stream().collect(Collectors.groupingBy(IncomeSumPojo::getOfficeId));

    2. 根据某个属性分组OfficeId,汇总某个属性Money:

    Map<String, Double> collect = list.stream().collect(Collectors.groupingBy(IncomeSumPojo::getOfficeId,Collectors.summingDouble(IncomeSumPojo::getMoney)));

    3. 根据某个属性添加条件过滤数据:

    list = list.stream().filter(u -> !u.getAmount().equals("0.00")).collect(Collectors.toList());

    4. 判断一组对象里面有没有属性值是某个值:

    List<Menu> menuList = UserUtils.getMenuList();
    boolean add = menuList.stream().anyMatch(m -> "plan:ctPlan:add".equals(m.getPermission()));

    5. 取出一组对象的某个属性组成一个新集合:

    List<String> tableNames=list.stream().map(User::getMessage).collect(Collectors.toList());

    6. list去重复:

    list = list.stream().distinct().collect(Collectors.toList());

    实例如下:

    package com.security.common.elk;
    
    import java.util.ArrayList;
    import java.util.Comparator;
    import java.util.List;
    import java.util.Map;
    import java.util.stream.Collectors;
    
    public class TEST {
    
        public static void main(String[] args) {
    
            List<Student> list = new ArrayList<>();
    
            Student student1 = new Student();
            student1.setAge("12");
            student1.setSex(0);
    
            Student student2 = new Student();
            student2.setAge("13");
            student2.setSex(2);
    
            Student student3 = new Student();
            student3.setAge("11");
            student3.setSex(1);
    
            Student student4 = new Student();
            student4.setAge("18");
            student4.setSex(1);
    
            Student student5 = new Student();
            student5.setAge("18");
            student5.setSex(0);
    
            Student student6 = new Student();
            student6.setAge("18");
            student6.setSex(2);
    
            Student student7 = new Student();
            student7.setAge("18");
            student7.setSex(2);
    
            list.add(student1);
    
            list.add(student2);
    
            list.add(student3);
    
            list.add(student4);
    
            list.add(student5);
    
            list.add(student6);
    
            list.add(student7);
    
            List<Demo> demos = new ArrayList();
    
            // 原始数据
            System.out.println("原始数据 组装list<demo>*******************");
    
            demos = list.stream().map(student -> new Demo(student.getAge(), student.getSex())).collect(Collectors.toList());
    
            demos.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 只取sex为0
    
            System.out.println("只取sex为0****************");
    
            List<Demo> demorm = demos.stream().filter(demo -> demo.getSex() == 0).distinct().collect(Collectors.toList());
    
            demorm.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 筛选年龄大于12岁
            System.out.println("筛选年龄大于12岁的*************");
    
            List<Demo> demoFilter = demos.stream().filter(demo -> Integer.valueOf(demo.getAge()) > 12).collect(Collectors.toList());
    
            demoFilter.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 排序
            System.out.println("排序******************");
            List<Demo> demoSort = demos.stream().sorted((s1, s2) -> s1.getAge().compareTo(s2.getAge())).collect(Collectors.toList());
            demoSort.forEach(demo -> {
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 倒序
            System.out.println("倒序****************");
    
            ArrayList<Demo> demoArray = (ArrayList) demos;
    
            Comparator<Demo> comparator = (h1, h2) -> h1.getAge().compareTo(h2.getAge());
    
            demos.sort(comparator.reversed());
    
            //or
            demos.sort(Comparator.comparing(Demo::getAge).reversed());
    
            demos.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 多条件正序
            System.out.println("多条件排序正序****************");
    
            demoArray.sort(Comparator.comparing(Demo::getSex).thenComparing(Demo::getAge));
    
            demoArray.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 多条件倒序
    
            System.out.println("多条件排序倒序 sex  倒序****************");
    
            demoArray.sort(Comparator.comparing(Demo::getSex).reversed().thenComparing(Demo::getAge));
    
            demoArray.forEach(demo -> {
    
                System.out.println("年龄 " + demo.getAge() + "  性别 " + demo.getSex() + ",");
    
            });
    
            // 按照年龄分组
    
            System.out.println("根据age分组结果为Map****************");
    
            Map demoOder = demos.stream().collect(Collectors.groupingBy(Demo::getAge));
    
            System.out.println(demoOder);
    
        }
    
    }
    
    class Demo {
    
        private String name;
    
        private Integer sex;
    
        private String age;
    
        public Demo(String age, Integer sex) {
    
            this.age = age;
    
            this.sex = sex;
    
        }
    
        public String getName() {
    
            return name;
    
        }
    
        public void setName(String name) {
    
            this.name = name;
    
        }
    
        public Integer getSex() {
    
            return sex;
    
        }
    
        public void setSex(Integer sex) {
    
            this.sex = sex;
    
        }
    
        public String getAge() {
    
            return age;
    
        }
    
        public void setAge(String age) {
    
            this.age = age;
    
        }
    
    }
    
    class Student {
    
        private String age;
    
        private Integer sex;
    
        public String getAge() {
    
            return age;
    
        }
    
        public void setAge(String age) {
    
            this.age = age;
    
        }
    
        public Integer getSex() {
    
            return sex;
    
        }
    
        public void setSex(Integer sex) {
    
            this.sex = sex;
    
        }
    
    }
    View Code

    java.util.List是一个接口,该接口继承了Collection接口,因此同样方法,作为接口只是定义规范不同。 实际的不同要看独特的定义或独特的实现才可以。

  • 相关阅读:
    GC垃圾回收算法
    Docker+nginx部署Springboot+vue前后端分离项目
    报错 ImportError: cannot import name 'AsyncContextManager'
    Python+Selenium定位不到元素(报错:selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element)
    淘宝网的发展史及其优缺点
    Python旅途——函数(1)
    正则表达式 -允许输入数字和小数点后两位
    表单的resetFileds函数重置为初始值而非清空数据
    做一个全局登录弹窗,任何地方访问
    浏览器到服务器的跨域问题
  • 原文地址:https://www.cnblogs.com/yuarvin/p/13529675.html
Copyright © 2011-2022 走看看