Collection java

package mycollection;

import java.util.ArrayList;
import java.util.Collection;

public class a01CollectionDemo1 {
    public static void main(String[] args) {

        /*
            public boolean add(E e)                          添加
            public  void  clear()                            清空
            public  boolean  remove(E e)                      删除
            public  boolean  contains(Object  obj)            判断是否包含
            public  isEmpty()                                 判断是否为空
            public  int  size()                               集合长度

         注意点:
        Collection是一个接口,我们不能直接创建他的对象。
        所以,现在我们学习他的方法时,只能创建他实现类的对象。
        实现类:ArrayList
*/
        //目的:为了学习Collection接口里面的方法
        //自己在做一些练习的时候,还是按照之前的方式去创建对象。
        Collection<String> coll = new ArrayList<>();


        //1.添加元素
        //细节1:如果我们要往List系列集合中添加数据,那么方法永远返回true,因为List系列的是允许元素重复的。
        //细节2:如果我们要往Set系列集合中添加数据,如果当前要添加元素不存在,方法返回true,表示添加成功。
        //                                       如果当前要添加的元素已经存在,方法返回false,表示添加失败。
        //                                       因为Set系列的集合不允许重复。
        coll.add("aaa");
        coll.add("bbb");
        coll.add("ccc");
        System.out.println(coll);//[aaa, bbb, ccc]

        //2.清空
        //coll.clear();

        //3.删除
        //细节1:因为Collection里面定义的是共性的方法,所以此时不能通过索引进行删除。只能通过元素的对象进行删除。
        //细节2:方法会有一个布尔类型的返回值,删除成功返回true,删除失败返回false
        //如果要删除的元素不存在,就会删除失败。
        System.out.println(coll.remove("aaa"));
        System.out.println(coll);//[bbb, ccc]


        //4.判断元素是否包含
        //细节:底层是依赖equals方法进行判断是否存在的。
        //所以,如果集合中存储的是自定义对象,也想通过contains方法来判断是否包含,那么在javabean类中,一定要重写equals方法。
        boolean result1 = coll.contains("bbb");
        System.out.println(result1);//true



        //5.判断集合是否为空
        boolean result2 = coll.isEmpty();
        System.out.println(result2);//false


        //6.获取集合的长度
        coll.add("ddd");
        int size = coll.size();
        System.out.println(size);//3



    }
}

创建学生类

package mycollection;

import java.util.Objects;

public class Student {
    private  String  name;
    private  int age;

    public Student() {
    }

    public Student(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }


    //重写equals
    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Student student = (Student) o;
        return age == student.age && Objects.equals(name, student.name);
    }



    public String toString() {
        return "Student{name = " + name + ", age = " + age + "}";
    }
}
package mycollection;

import java.util.ArrayList;
import java.util.Collection;

public class a02CollectionDemo {
    public static void main(String[] args) {
        //1.创建集合的对象
        Collection<Student> coll = new ArrayList<>();

        //2.创建三个学生对象
        Student s1 = new Student("zhangsan", 23);
        Student s2 = new Student("lisi", 24);
        Student s3 = new Student("wangwu", 25);

        //3.把学生对象添加到集合当中
        coll.add(s1);
        coll.add(s2);
        coll.add(s3);

        //4.判断集合中某一个学生对象是否包含
        Student s4 =new Student("zhangsan",23);
        //如果同姓名和同年龄 就认为是同一个学生
        //因为contains方法在底层依赖equals方法判断对象是否一致
        //如果存的是自定义对象 没有重写equals方法 那么默认使用Object类中的equals方法进行判断 而Object类中的equals方法 依赖地址值进行判断
        //需求 如果同姓名和同年龄 就认为是一个学生
        //所以  需要在自定义的JavaBean类中  重写equals方法就可以
        System.out.println(coll.contains(s4));//true




    }
}

 迭代器

package mycollection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class a03CollectionDemo {
    public static void main(String[] args) {
        /*
        Collection系列集合三种通用的遍历方式
        1.迭代器遍历
        2.增强for遍历
        3.lambda表达式遍历

        迭代器遍历相关的三个方法
              Iterator<E> iterator  :获取一个对象
              boolean hasNext()      :判断当前指向的位置是否有元素
              E  next()              :获取当前指向的元素并移动指针

       * */

        //1.创建集合并添加元素
        Collection<String> coll =new ArrayList<>();
        coll.add("aaa");
        coll.add("bbb");
        coll.add("ccc");
        coll.add("ddd");

        //2.获取迭代器对象
        //迭代器好比是一个箭头  默认指向集合的0索引处
        Iterator<String>it =coll.iterator();
        //3.利用循环不断的去获取集合中的每一个元素
        while (it.hasNext()){
            //4.next方法的两件事情 获取元素并移动指针
            String str= it.next();
            System.out.println(str);
        }
    }
}

 

 

package mycollection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class a04CollectionDemo {
    public static void main(String[] args) {

 /*
        迭代器的细节注意点:
            1.报错NoSuchElementException
            2.迭代器遍历完毕,指针不会复位
            3.循环中只能用一次next方法
            4.迭代器遍历时,不能用集合的方法进行增加或者删除
       */

        //1.创建集合并添加元素
        Collection<String> coll = new ArrayList<>();
        coll.add("aaa");
        coll.add("bbb");
        coll.add("ccc");
        coll.add("ddd");

        //2.获取迭代器对象
        //迭代器就好比是一个箭头,默认指向集合的0索引处
        Iterator<String> it = coll.iterator();
        //3.利用循环不断的去获取集合中的每一个元素
        while(it.hasNext()){
            //4.next方法的两件事情:获取元素并移动指针
            String str = it.next();
            System.out.println(str);
        }

        //当上面循环结束之后,迭代器的指针已经指向了最后没有元素的位置
        //System.out.println(it.next());//NoSuchElementException

        //迭代器遍历完毕,指针不会复位
        System.out.println(it.hasNext());

        //如果我们要继续第二次遍历集合,只能再次获取一个新的迭代器对象
        Iterator<String> it2 = coll.iterator();
        while(it2.hasNext()){
            String str = it2.next();
            System.out.println(str);
        }
    }
}

 

 

package mycollection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class a05CollectionDemo {
    public static void main(String[] args) {

 /*
        迭代器的细节注意点:
            1.报错NoSuchElementException
            2.迭代器遍历完毕,指针不会复位
            3.循环中只能用一次next方法
            4.迭代器遍历时,不能用集合的方法进行增加或者删除
       */

        //1.创建集合并添加元素
        Collection<String> coll = new ArrayList<>();
        coll.add("aaa");
        coll.add("bbb");
        coll.add("ccc");
        coll.add("ddd");

        //2.获取迭代器对象
        //迭代器就好比是一个箭头,默认指向集合的0索引处
        Iterator<String> it = coll.iterator();
        //3.利用循环不断的去获取集合中的每一个元素
        while (it.hasNext()) {
            //4.next方法的两件事情:获取元素并移动指针
            String str = it.next();

            if ("bbb".equals(str)){
               // coll.remove("bbb");
                it.remove();
            }
            System.out.println(coll);
        }

    }
}

 

 

 增强for

package mycollection;

import java.util.ArrayList;
import java.util.Collection;

public class a06CollectionDemo {
    public static void main(String[] args) {
          /*
        Collection系列集合三种通用的遍历方式
        1.迭代器遍历
        2.增强for遍历
        3.lambda表达式遍历

        增强for格式
           for(数据类型  变量名: 集合/数组){
           }


        */
        //1.创建集合并添加元素
        Collection<String> coll =new ArrayList<>();
        coll.add("zhangsan");
        coll.add("lisi");
        coll.add("wangwu");
        //2.利用增强for进行遍历
        //注意点
        //s其实就是一个第三方变量 在循环的过程中依次表示集合中的每一个数据
        for (String s :coll ) {
           s="qqq";
        }
        System.out.println(coll);




    }
}

 

 

 Lambda表达式

package mycollection;

import java.util.ArrayList;
import java.util.Collection;
import java.util.function.Consumer;

public class a07CollectionDemo {
    public static void main(String[] args) {
          /*
        Collection系列集合三种通用的遍历方式
        1.迭代器遍历
        2.增强for遍历
        3.lambda表达式遍历

        lambda表达式遍历:
              default  void  foreach(consumer<? super T>action):
        */
        //1.创建集合并添加元素
        Collection<String> coll =new ArrayList<>();
        coll.add("zhangsan");
        coll.add("lisi");
        coll.add("wangwu");
        //2.利用匿名内部类的形式
        //底层原理
        //其实也会自己遍历集合 依次得到每一个元素
        //把得到的每一个元素传递给下面的accept方法
        //s依次表示集合中的每一个数据
        
        
        
//        coll.forEach(new Consumer<String>() {
//            @Override
//            public void accept(String s) {
//                System.out.println(s);
//            }
//        });

        //lambda表达式
        // ()->{}
        coll.forEach(s -> System.out.println(s));
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值