8.Java----集合

主要分为Collection和Map

1.Collection

1.1 List:有序,可重复元素

1.1.1 ArrayList,LinkedList
//List:有序,可重复元素
        //ArrayList,LinkedList
    

1.2 Set接口:无序,不可重复元素

1.2.1HashSet,LinkedHashSet,TreeSet
//Set:无序,不可重复元素
        // HashSet:主要实现类,线程不安全,可以存储null值
        //底层是数组,数组元素为链表,添加元素时,调用元素的hashcode()计算哈希值(通过哈希值计算出在数组中的位置)
        //当位置上没有元素时,直接添加
        // 有元素时,哈希值相同时,使用equils方法比较
        // 有元素时,哈希值不同,在链表中添加元素
            //LinkedHashSet:作为hashset的子类,遍历其内部结构时,可以按照添加的顺序遍历
        //TreeSet:可以按照添加对象的指定属性,进行排序(使用比较器)
@Test
    public void test2(){
        HashSet hashSet = new HashSet();
        hashSet.add("11");
        hashSet.add(new Person("p1",11).hashCode());
        hashSet.add(new Person("p1",11).hashCode());//如果Person类中没有重写hashCode(),那么就调用object中的hashcode()
        LinkedHashSet linkedHashSet = new LinkedHashSet();
        linkedHashSet.add("22");
        linkedHashSet.add("221");
        linkedHashSet.add("223");
        //必须添加同一类型
        TreeSet treeSet = new TreeSet();
        treeSet.add(111);
        treeSet.add(1112);
        treeSet.add(1111);
        
        Iterator iterator = hashSet.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }
    }

2.Map

//Map:双列数据,存储key-value对的数据 ---类似于高中的函数:y=f(x)
// Map中的key:无序的,不可重复的,使用Set存储所有的key,当key为对象时,此对象类需要重写equals()和hashcode()(参考hashset)
//Map中的value:无序的,可重读的,使用Collection存储,当value为对象时,需要重写equals()
//一个键值对 key-value构成了一个Entry对象,jdk8中为node
//Map中的entry:无序的,不可重复的,使用Set存储所有的Entry
    //HashMap:主要实现类
    //使用put()时,先根据key所在类的hashcode()计算key中的哈希值,然后得到在entry数组中的存放位置
//如果位置上为空,则添加成功
//如果位置上不为空,则与此位置上的数据比较哈希值,
    //如果哈希值不一样,则添加成功
    //如果哈希值一样,就调用key所在类的equals(),如果一样就覆盖,不一样就添加
        //LinkedHashMap
    //TreeMap:
    //Hashtable:
        //Properties:
@Test
    public void test3(){
        HashMap hashMap = new HashMap();
        hashMap.put("test1","111");
        hashMap.put("test2","222");
        hashMap.put("test3","333");
        hashMap.put("test4","444");
        Set set = hashMap.keySet(); //获取所有的key,保存在set集合中
        Collection values = hashMap.values();//获取所有的value,保存在Collection中
        Set set1 = hashMap.entrySet(); //获取所有的key-value对,保存在set集合中
        for (Object o : set) {
            System.out.println(o);
        }
        for (Object value : values) {
            System.out.println(value);
        }
        for (Object o : set1) {
            System.out.println(o);
        }
    }

3.集合遍历

//遍历,使用iterator,每次调用iterator(),都会生成指向头部的指针
        Iterator iterator = arrayList.iterator();
        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }

        //使用增强for循环,foreach,内部还是调用的迭代器
        for (Object o : arrayList) {
            System.out.println(o);
        }

4.Collections工具类

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java集合类可用于存储数量不等的对象,并可以实现常用的数据结构如栈,队列等,Java集合还可以用于保存具有映射关...
    小徐andorid阅读 1,976评论 0 13
  • 原文地址 Java集合 Java集合框架:是一种工具类,就像是一个容器可以存储任意数量的具有共同属性的对象。 Ja...
    gyl_coder阅读 996评论 0 8
  • 简介 1.所有的集合类都位于java.util包下,Java的结合主要由两个接口类派生出来,分别是Collecti...
    yunqing_71阅读 2,562评论 0 2
  • 集合类框架的介绍: ![Java 集合类框架](https://upload-images.jianshu.io/...
    LynnGuo阅读 764评论 0 1
  • 四、集合框架 1:String类:字符串(重点) (1)多个字符组成的一个序列,叫字符串。生活中很多数据的描述都采...
    佘大将军阅读 775评论 0 2