Collection集合的功能:
            Object[] toArray() 将集合转成数组
            Iterator iterator() 通过方法的调用 获取Iterator迭代器对象
   //  遍历集合的常见方式
        //方式1 Object[] toArray() 将集合转成数组
        //普通for 循环 遍历集合 toArray()方法 将集合转成Object[]数组
        Object[] arr = c.toArray();
        for(int i=0;i<arr.length;i++){
            System.out.println(arr[i]);
        }
        
        Collection c2 = new ArrayList();
        c2.add(new Student("王二麻子",20));
        c2.add(new Student("赵四",40));
        Object[] arr2 = c2.toArray();
        for(int i=0;i<arr2.length;i++){
            //向下转型
            Student s = (Student)arr2[i];
            System.out.println(s.getName());
        }
        //方式2 增强for循环
        /*
            格式
                for(元素类型 变量名:要遍历的范围){
                    循环体语句
                }
                变量名 随便写
                但是在增强for循环中 它代表的是当前遍历范围内的元素本身
            缺点:
                丢掉了索引
                就不能根据索引获取元素了
        */
        for(Object o:arr2){
            System.out.println(o);//arr2[i] 元素本身
            //向下转型
            Student s = (Student)o;
            System.out.println("增强for 循环:::::"+s.getName());
        }

int[] arr3 ={1,2,3};
        for(int x:arr3){
            System.out.println(x);
        }
      迭代器:
       public static void main(String[] args)
    {
        Collection c = new ArrayList();
        c.add("a");
        c.add("b");
        c.add("c");
        c.add("d");
        System.out.println(c);
        c.add("qqq");
        //Iterator iterator() 迭代器
        Iterator it = c.iterator();
        /*
            boolean hasNext() 如果仍有元素可以迭代,则返回 true。
            Object next() 返回迭代的下一个元素。
            void remove() 从迭代器指向的 collection 中移除迭代器返回的最后一个元素(可选操作)。
        */
        //循环的结束条件是什么 hasNext()--> false 就结束
        while(it.hasNext()){
            Object obj = it.next();
            System.out.println(obj);
            if("b".equals(obj)){//为了避免出现空指针异常 在使用equals进行比较时 建议将常量写在前面
                //it.remove();
                //c.remove("b");//ConcurrentModificationException 多线程并发访问异常
            }
        }
        c.add("cccc");
        c.remove("a");
        System.out.println(c);
    }

/*list
        增
            add(index,element)在指定位置添加元素 角标从0开始
            addAll(index,Collection)
        删
            remove(index)删除指定位置的元素 角标从0开始
        改
            set(int index, E element) 修改指定位置的元素 角标从0开始
        查
            get(int index) 获取指定位置的元素
            subList(int fromIndex, int toIndex)  
        */
创建List 集合 存储Student对象 并对其进行排重处理
public static void main(String[] args)
    {
        //创建List 集合 存储Student对象 并对其进行排重处理
        List list = new ArrayList();
        list.add(new Student("张飞",30));
        list.add(new Student("诸葛亮",40));
        list.add(new Student("曹操",50));
        list.add(new Student("诸葛亮",40));

System.out.println(list);

ArrayList newList = getSingle(list);
        System.out.println(newList);
    }
    public static ArrayList getSingle(List list){
        ArrayList al = new ArrayList();
        Iterator it = list.iterator();
        while(it.hasNext()){
            Object obj = it.next();
            if(!al.contains(obj)){//contains 包含 底层依托的是equals方法 Object类 默认equals方法比较的是地址值
                al.add(obj);
            }
        }
        return al;
    }
}

student类中的contains 包含 底层依托的是equals方法 Object类 默认equals方法比较的是地址值
    //重写 equals方法 比较属性是否相同 (不会看15)
    public boolean equals(Object obj){
        if(!(obj instanceof Student)){
            return false;
        }
        Student stu = (Student)obj;
        return this.name.equals(stu.name) && this.age == stu.age;
    }

List集合特有的迭代器ListIterator
            hasNext()
            next()
            注意 指针 先向后移动 再移动回来 单独写previous 获取不到数据 必须
                        先将指针向后移动 才能向前移动
            hasPrevious()
            previous()
        //List集合特有的迭代器 ListIterator
        List list = new ArrayList();
        list.add(new Student("张三", 23));
        list.add(new Student("李四", 24));
        list.add(new Student("王五", 25));
        for(int i=0;i<list.size();i++){
            Student stu = (Student)list.get(i);
            System.out.println(stu.getName()+",,,"+stu.getAge());
        }
        //ListIterator
        ListIterator it = list.listIterator();
        while(it.hasNext()){
            Student stu = (Student)it.next();
            System.out.println("ListIterator::::"+stu.getName());
            if("张三".equals(stu.getName())){
                it.add(new Student("赵四", 44));
            }
        }
        System.out.println(list);
        //注意 指针 先向后移动 再移动回来 单独写previous 获取不到数据 必须 先将指针向后移动 才能向前移动
        while(it.hasPrevious()){
            System.out.println("结果:"+it.previous());
        }
    }
Vector
        Vector集合 底层是数组
        Vector 和 ArrayList使用方法一样
        遍历方式不同
            Enumeration<E> elements()
            枚举遍历 只能是Vector使用 高版本的List集合无法使用
            实际开发中 使用近乎都是ArrayList
              public static void main(String[] args) {
        Vector v = new Vector();
        v.addElement("c");
        v.addElement("b");
        v.addElement("a");
        System.out.println(v);
        /*
         * 遍历集合 方式 使用枚举遍历
         * */
        Enumeration en = v.elements();
        while(en.hasMoreElements()){
            System.out.println(en.nextElement());
        }
    }

    Set        
             排序(升序) 按照自然顺序排序 ASCII码表的顺序排序
             TreeSet集合 如何给自定义数据类型进行排序?
            第一种方式====我是方法===========
                让自定义类 实现 public interface Comparable<T>接口
                此接口强行对实现它的每个类的对象进行整体排序。
                这种排序被称为类的自然排序,
                类的 compareTo 方法被称为它的自然比较方法。
                /*
                 * 返回:负整数、零或正整数,根据此对象是小于、等于还是大于指定对象
                 * 此对象 小于 指定对象 返回 负整数
                 * 此对象 等于 指定对象 返回 0
                 * 此对象 大于 指定对象 返回正整数
                 * */========我是方法==============
            public int compareTo(Object o) {
        // 此对象 this  和  指定对象Object进行比较 按照年龄排序
        /*
         * 返回:负整数、零或正整数,根据此对象是小于、等于还是大于指定对象
         * 此对象 小于 指定对象 返回 负整数
         * 此对象 等于 指定对象 返回 0
         * 此对象 大于 指定对象 返回正整数
         * */
        Teacher t = (Teacher)o;//向下转型
        //System.out.println(this.getAge()+","+this.getName()+",,"+t.getAge()+".."+t.getName());
        if(this.getAge() < t.getAge()){
            return -1;
        }
        if(this.getAge() == t.getAge()){
            //equals
            //String 类的 compareTo方法
            //如果参数字符串等于此字符串,则返回值 0;
            //如果此字符串按字典顺序小于字符串参数,则返回一个小于 0 的值;
            //如果此字符串按字典顺序大于字符串参数,则返回一个大于 0 的值。
            return this.getName().compareTo(t.getName());
            //return 0;
        }
        return 1;

第二种方式=======我是方法================
                让容器具备比较性
                在创建TreeSet集合的同时 传入public interface Comparator<T>接口
                重写 compare方法
                强行对某个对象 collection 进行整体排序 的比较函数。
                /*
                 * 参数:
                    o1 - 要比较的第一个对象。
                    o2 - 要比较的第二个对象。
                    返回:
                    根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。
                        第一个参数 小于 第二个参数 返回 负整数
                        第一个参数 等于 第二个参数 返回 0
                        第一个参数 大于 第二个参数 返回 正整数

=============我是方法=====================

遍历集合的常见方式,排序,用lambda表示是怎样的的更多相关文章

  1. Java Enum枚举 遍历判断 四种方式(包括 Lambda 表达式过滤)

    示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...

  2. java里遍历map的常见方式

    public static void main(String[] args) { Map<String, String> map = new HashMap<String, Stri ...

  3. Java List集合 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.ArrayList; import java.util.List; /** * @A ...

  4. Java Map集合 遍历 五种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.HashMap; import java.util.Iterator; import ...

  5. Java Array数组 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...

  6. java8的lambda过滤list遍历集合,排序

    1.根据属性过滤list List<AllManagerBean> testLists = broadCastRoomMapper.allManagerlist(); List<Al ...

  7. Lambda表达式遍历集合

    1.Collection Java 8 为Iterable接口新增了一个forEach(Consumer action)默认方法,该方法所需参数的类型是一个函数式接口,而Iterable接口是Coll ...

  8. Java forEach 方式遍历集合(Java 8 新特性)

    JDK 8 新增 forEach 方式遍历集合,这种方式比原来的 for each 循环还要简洁和便利. 需要注意:如果你计算机安装的是 JDK 8 以前的版本,是不支持 JDK 8 的新特性 Lis ...

  9. 集合遍历数组三种常用方式(Collecton和Map)

    Collection集合遍历数组的三种方式: 迭代器 foreach(增强for循环) JDK1.8之后的新技术Lambda 迭代器: 方法:public Iterator inerator():获取 ...

随机推荐

  1. python 使用 UTF-8 编码

    题记 一般我喜欢用 utf-8 编码,在 python 怎么使用呢? 使用utf-8 文字 在 python 源码文件中用 utf-8 文字.一般会报错,如下: File "F:\works ...

  2. 递归、尾递归和使用Stream延迟计算优化尾递归

    我们在学数据结构的时候必然会接触栈(Stack),而栈有一个重要的应用是在程序设计语言中实现递归.递归用途十分广泛,比如我们常见的阶乘,如下代码: 1234 public static int (in ...

  3. 从846家初创倒下 看A轮融资后的悬崖

    看A轮融资后的悬崖" title="从846家初创倒下 看A轮融资后的悬崖"> 相比往年,今年的寒冷冬天来得更早.在互联网行业,今年的"大雪"更 ...

  4. CSS 双飞翼布局

    10 Jul 2016 » CSS 双飞翼布局:总共分三栏,左侧栏Left,中间主栏Main,右侧栏Right 第一步,建立三个div,不过注意,中间Main需要加一个wrap div. 整个结构看起 ...

  5. [python每日一练]--0012:敏感词过滤 type2

    题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...

  6. JobScheduler 和 JobService

    使用AlarmManager.IntentService和PendingIntent相互配合,创走周期性的后台任务,实现一个完全可用的后台服务还需要手动执行以下操作.   计划一个周期性任务    ...

  7. Spring源码阅读笔记03:xml配置读取

    前面的文章介绍了IOC的概念,Spring提供的bean容器即是对这一思想的具体实现,在接下来的几篇文章会侧重于探究这一bean容器是如何实现的.在此之前,先用一段话概括一下bean容器的基本工作原理 ...

  8. MongoDB监控及报警

    转载请注明出处:https://www.cnblogs.com/shining5/p/11142357.html MongoDB监控及报警 Prometheus是由SoundCloud开发的开源监控报 ...

  9. java基础进阶篇(四)_HashMap------【java源码栈】

    目录 一.前言 二.特点和常见问题 二.接口定义 三.初始化构造函数 四.HashMap内部结构 五.HashMap的存储分析 六.HashMap的读取分析 七.常用方法 八.HashMap 的jav ...

  10. CSS单位计算总结

    CSS单位总结 公共部分css body { background-color: #000; color: skyblue; margin: 0; padding: 0; } body>div& ...