栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

集合框架的概述

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

集合框架的概述

  • 1、集合、数组都是对多个数据进行存储操作的结构,简称Java容器
  • 说明:此时的存储主要指的是内存层面的存储,不涉及到持久化的存储
  • 2、数组在数据存储方面的缺点:
  • 一旦初始化以后,其长度就不可修改;

  • 数组中提供的方法非常有限,对于添加、删除、插入数据等操作,非常不便且效率不高;

  • 获取数组中实际元素的个数的需求,数组没有现成的属性或方法可用(.length只是获取数组的长度);

  • 数组存储数据的特点:有序、可重复。对于无序、不可重复的需求,不能满足。

集合框架 Collection接口:单列集合,用来存储一个一个的对象 List接口:存储有序的、可重复的数据;
  • ArrayList、linkedList、Vector
Set接口:存储无序的、不可重复的数据;
  • HashSet、linkedHashSet、TreeSet
Map接口:双列集合,用来存储一对(key-value)一对数据
  • HashMap、linkedHashMap、TreeMap、Hashtable、Properties
Collection接口的方法

向Collection接口的实现类的对象中添加数据obj时,要求obj所在类要重写equals()方法

  • contains(Object obj):判断当前集合中是否包含obj
  • 在判断时会调用obj对象所在类的equals(),有些类如string的自动重写过,一般obj所在的类需要重写equals方法
  • containsAll(Collection coll):判断形参coll中所有元素都在当前集合中
  • remove(Object obj):从当前集合中移除obj元素
  • removeAll(Collection coll):从当前集合中移除coll中所有的元素
  • retainAll(Collection coll):交集。获取当前集合和coll集合的交集,并将交集返回给当前集合
  • equals(Object obj):要想返回true,需要当前集合与形参集合的元素都相同(具体还要看集合的类型,如果是ArrayList,则必须有序相同)
  • hashCode():返回当前对象的哈希值
  • toArray():集合----->数组
@Test
    public void test1(){
        Collection coll = new ArrayList();
        coll.add(123);
        coll.add(456);

        Object[] arr = coll.toArray();
        for(int i = 0;i < arr.length;i++){
            System.out.println(arr[i]);

        }
    }
  • 拓展:数组------>集合 调用Arrays的静态方法asList()
@Test
    public void test2(){
        String[] s = new String[]{"AA", "BB", "CC"};
        List list = Arrays.asList(s);
        System.out.println(list);//[AA, BB, CC]

        List l1 = Arrays.asList(new Integer[]{123, 456});
        System.out.println(l1.size());//2

        List l2 = Arrays.asList(new int[]{123, 456});
        System.out.println(l2.size());//1

    }

注意这里()内要是包装类,不然会被当成一个整体的对象

  • iterator():返回iterator接口的实例,用于遍历集合元素 使用迭代器Iterator接口
  • 内部的方法:hasNext()和Next()
@Test
    public void test3(){
        Collection coll = new ArrayList();
        coll.add(123);
        coll.add(456);
        coll.add(true);

        Iterator iterator = coll.iterator();

        while(iterator.hasNext()){
            System.out.println(iterator.next());
        }
    }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/334257.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号