Java入门第三季 常用工具类之集合框架

本文深入探讨Java集合框架,包括List、Set、Map等核心接口及其主要实现类的特点与应用场景,对比不同集合类的优劣,并介绍泛型的正确使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

接上篇Java入门第三季 常用工具类

Java 中的集合框架(上)

Java中的集合类:是一种工具类,就像是容器,储存任意数量的具有共同属性的对象
集合的作用

  • 在类的内部,对数据进行组织
  • 简单而快速的搜索大数量的条目
  • 有的集合接口,提供了一系列排列有序的元素,并且可以在序列中间快速的插入或者删除有关元素
  • 有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找对应的唯一对象,而这个关键字可以是任意类型

与数组的对比

  1. 数组的长度固定,集合长度可变
  2. 数组只能通过下标访问元素,类型固定,而有的集合可以通过任意类型查找所映射的具体对象

Java中的集合
集合

接口别称说明实现类
List接口序列存储元素排列有序且可重复。实现类:1、ArrayList,数组序列;2、LinkedList,链表。
Queue接口队列存储元素排列有序且可重复。主要用于存储数据,而不是处理数据实现类:LinkedList,链表。
Set接口存储元素无序且不可重复。重复添加对象,只会保留一个对象(的引用),且保留的是第一次添加的那一个实现类:HashSet,哈希集。
Map接口内部以两个对象(任意类型)为一个映射去存储数据,这一个映射就是Entry类(Map的内部类)的实例。实现类:hashMap,哈希表。

其中ArrayList 、 HashSet、 HashMap使用频率最高

集合框架

各集合的比较详解java集合框架
实现集合接口的类一般遵循<实现方式>+<接口>的命名方式

Collection接口&List接口简介

List接口及其实现类——ArrayList
List可以精确的控制每个元素的插入位置,或删除某个位置元素
ArrayList底层是由数组实现的

vector与ArrayList区别

集合类同步性数据增长
vector同步(线程安全)【大数据量】缺省情况下自动增长原来一倍的数组长度
ArrayList异步(线程不安全)【效率高】原来的50%

学生选课

//用于存放备选课程的List
public List coursesToSelect;
//无参的构造方法    
//List是一个接口,不能直接new List,而应该使用ArrayList或者LinkedList(实现了List接口)来实例化
public ListTest() {
    this.coursesToSelect = new ArrayList();
}

实例化:创建一个类的实例,也即一个对象(在内存中分配地址和空间)
初始化:为各类成员赋予初始值

4种形式添加(课程对象)

//创建一个课程对象,并通过调用add方法,添加到备选课程List中
Course cr1 = new Course("1" , "数据结构");//有参的构造方法
coursesToSelect.add(cr1);//从第0位开始存
//1、对象存入集合都会变成Object类型,取出时需要类型转换
Course temp = (Course) coursesToSelect.get(0);
//2、集合.add(索引位置, 添加的对象);
//会把原来最初0位的cr1给挤下去,变成第一位,而cr2变成最初第0位【不是覆盖】
coursesToSelect.add(0, cr2);

//数组形式添加
Course[] course = {new Course("3", "离散数学"), new Course("4", "汇编语言")};
coursesToSelect.addAll(Arrays.asList(course));//3、将数组转化为List对象

//数组 带有索引位置的添加
Course[] course2 = {new Course("5", "高等数学"), new Course("6", "大学英语")};
coursesToSelect.addAll(2, Arrays.asList(course2));

迭代器只用来遍历集合中的元素,本身不具备任何存储元素【迭代器依赖于某个集合而存在的】不能独立存在

//通过集合的iterator方法,取得迭代器的实例
Iterator<Course> it = coursesToSelect.iterator();
System.out.println("有如下课程待选(通过迭代器访问):");
while(it.hasNext()) {
    Course cr = it.next();
    System.out.println("课程:" + cr.id + ":" + cr.name);
}
//通过foreach形式
for (Object obj : coursesToSelect) {
    Course cr = (Course) obj;
    System.out.println("课程:" + cr.id + ":" + cr.name);
}

应用泛型管理课程

应用泛型管理课程1
集合中的元素,可以是任意类型的对象(对象的引用)
如果把某个对象放入集合,则会忽略他的类型,而把他当做object处理
泛型则是规定了某个集合只可以存放特定类型的对象
会在编译期间进行类型检查【泛型集合中,不能添加泛型规定的类型及其【子类型】以外的对象,否则会报错!】【泛型集合可以添加泛型的子类型的对象实例
可以直接按指定类型获取集合元素
应用泛型管理课程2
1、泛型集合中的限定类型不能使用基本数据类型
2、可以通过使用包装类限定允许存入的基本数据类型
可以通过使用包装类限定允许存入的基本数据类型

基本类型必须使用包装类作为泛型!

通过set集合管理课程

Set接口及其实现类——HashSet

  • Set是元素无序并且不可重复的集合,被称为集
  • HashSet——哈希集,是Set的一个重要实现类
//Student类里
public Set<Course> courses;
//有参构造器
public Student(String id, String name) {
    this.id = id;
    this.name = name;
    this.courses = new HashSet<Course>();
}

1、Set没有像List中set()方法一样修改集合集合.set(索引, new 有参构造器(入参1, 入参2));因为List是有序的,可以指定位置,而Set是无序的。
元素在Set集合中的位置是由该元素的HashCode决定的,其位置其实是固定的。
2、查询遍历时,Set不能用get()方法去获取,因为无序没有指定索引ID,但可以使用foreach和iterator来遍历,但是每次遍历出来可能顺序都不一样,还是因为无序造成的。
3、Set中的size(),add(),addAll(),remove(),removeAll()与List类似。
4、Set还可以添加null;(它的长度不是0,有值,只不过值为空)

Set中,添加某个对象,无论添加多少次, 最终只会保留一个该对象(的引用)
并且保留的是第一次添加的那一个

Java 中的集合框架(中)

Map和HashMap

Map接口:
1、Map提供了一种映射关系,其中的元素是以键值对(Key-value)的形式存储的,能够实现根据key快速查找value
2、Map中的键值对以Entry类型的对象实例形式存在
3、键(key值)不可重复,value值可以
4、每个键最多只能映射到一个值
5、Map接口提供了分别返回key值集合【keySet()】,value值集合【values()】以及Entry(键值对)集合的方法【entrySet()】
6、Map支持泛型,形式如:Map<K,V>
HashMap类:

  • HashMap是Map的一个重要实现类,也是最常用的,基于哈希表实现
  • HashMap中的Entry对象是无序排列
  • key值和value值都可以为null,但一个HashMap只能有一个key值为null映射(key值不可重复)【key:null,value:null 占一个map的size 即长度不是0,有值,只不过值为空

遍历前要检查是否为null。如果遍历一个空map对象,for each循环将抛出NullPointerException异常

keySet()返回的是所有键的一个set集合

// 通过keySet方法,返回Map中的所有“键”的Set集合
Set<String> keySet = students.keySet();
// 取得students的容量用size()
System.out.println("总共有:" + students.size() + "个学生!");
// 遍历keySet,取得每一个键,再调用get方法取得每个键对应的value
for (String stuId : keySet) {
    Student st = students.get(stuId);
    if (st != null)
        System.out.println("学生:" + st.name);
}

//values()返回所有的“值”集合(Collection)

hashMap实现Map接口,hashMap中的映射是无序的,因此输出也是无序的;
Map的get()方法中传入key值就可以取得key值对应的对象

// 通过entrySet方法,返回Map中的所有键值对
Set<Entry<String, Student>> entrySet = students.entrySet();
for (Entry<String, Student> entry : entrySet) {
    System.out.println("取得键:" + entry.getKey());
    System.out.println("对应的值为:" + entry.getValue().name);
}

HashMap与HashTable区别

集合类历史原因同步性
HashTable基于陈旧的Dictionary类同步(线程安全)不能放入空值null
HashMapMap接口的一个实现异步(线程不安全)【效率高】key-value可以为null

map接口

LinkedHashMap和HashMap的比较使用

Java 中的集合框架(下)

判断是否包含

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值