Collection接口的常用方法

package com.atguigu.java;

import org.junit.Test;

import java.util.*;

/**
 * @author WHR
 * @create 2021-03-13-11:38
 * 一、集合框架的概述
 * 1.集合、数组都是对多个数据进行存储操作的结构,简称Java容器。
 * 说明:此时的存储,主要指的是内存层面的存储,不涉及到持久化的存储(.txt,.jpg,.avi,数据库中)
 * <p>
 * 2.1数组在存储多个数据方面的特点:
 * >一旦初始化以后,其长度就确定了。
 * >数组一旦定义好,其元素的类型也就确定了。我们也就只能操作指定类型的数据了。
 * 比如: String[]arr;int[] arr1;object[] arr2;
 * <p>
 * 2.2数组在存储多个数据方面的缺点:
 * >一旦初始化以后,其长度就不可修改。
 * >数组中提供的方法非常有限,对于添加、删除、插入数据等操作,非常不便,同时效率不高。
 * >获取数组中实际元素的个数的需求,数组没有现成的属性或方法可用
 * >数组存储数据的特点:有序、可重复。对于无序、不可重复的需求,不能满足。
 * <p>
 * <p>
 * 二、集合框架
 * /---- Collection接口:单列集合,用来存储一个一个的对象
 * <p>
 * /---- List接口:存储有序的、可重复的数据    --->"动态"数组
 * /--- ArrayList/LinkedList/Vector
 * /---- Set接口:存储无序的、不可重复的数据   --->"集合"
 * /---HashSet/LinkedHashSet/TreeSet
 * <p>
 * /---- Map接口:双列集合,用来存储一对(key - value)一对的数据 --->"函数" y = f(x)
 * /---HashMap/LinkedHashMap/TreeMap/HashTable/Properties
 */

public class CollectionTest {
    @Test
    public void test1() {
        Collection coll = new ArrayList();

        //add(object e):将元素e添加到集合coll中
        coll.add("AA");
        coll.add('a');
        coll.add(123);
        coll.add(new Date());

        //size():获取添加的元素个数
        System.out.println(coll.size());

        //addAll(Collection coll1):将coLl1集合中的元素添加到当前的集合中

        Collection coll1 = new ArrayList();
        coll1.add(123);
        coll1.add("123");
        coll.addAll(coll1);
        System.out.println(coll.size());
        System.out.println(coll);

        //clear():清空集合元素
        //coll.clear();

        //isEmpty():判断集合中是否为空
        System.out.println(coll.isEmpty());

        //contains():
        //向Collection接口的实现类的对象中添加数据obj时,要求obj所在类要重写equals( ).
        System.out.println(coll.contains(123));


    }

    @Test
    public void test2() {
        Collection coll = new ArrayList();
        coll.add(123);
        coll.add(new Person("TOM", 12));


        //向Collection接口的实现类的对象中添加数据obj时,要求obj所在类要重写equals( ).
        System.out.println(coll.contains(new Person("TOM", 12)));

        //containsAll(Collection coll1):判断形参coll1中的所有元素是否都存在于当前集合中
        Collection coll1 = Arrays.asList(123, 4565);
        System.out.println(coll.containsAll(coll1));

        //remove(Obj o):从当前集合中移除Object元素
        coll.remove(new Person("TOM", 12));
        System.out.println(coll.contains(new Person("TOM", 12)));

        //retainAll():交集:获取当前集合和coll1集合的交集,并返回给当前集合
        coll.retainAll(coll1);
        System.out.println(coll);

        //removeAll(Collection coll1):从当前集合中移除coll1中所有的元素
        coll.removeAll(coll1);
        System.out.println(coll);

        //equals(Obj o):要想返回true,需要当前集合和形参集合的元素都相同。


    }

    @Test
    public void test3() {
        Collection coll = new ArrayList();

        coll.add("AA");
        coll.add('a');
        coll.add(123);
        coll.add(new Person("Jerry", 21));

        //hashCode():返回当前对象的哈希值
        System.out.println(coll.hashCode());

        //集合 ---> 数组:toArray()
        Object[] array = coll.toArray();
        System.out.println(Arrays.toString(array));


        List<String> list = Arrays.asList(new String[]{"AA", "BB", "CC"});//list.size() = 1

//        List<int[]> list = Arrays.asList(new int[]{2131,312,31});//list.size() = 1
//        List<Integer> list = Arrays.asList(new Integer[]{2131,312,31});//list.size() = 3

//        list.remove(new String[]{"AA", "BB", "CC"});
        System.out.println(list.size());

        //iterator():返回Iterator接口的实例,用于遍历集合元素

    }

}

class Person {
    private String name;
    private int age;

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

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

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}





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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值