【Java】之集合总结(上)

简介: 用来存储不同类型的多个对象的一些特殊类的统称为集合,可以简单的理解为存储不同数据类型的动态数组(因为数组的长度是一定的,而集合长度是可以改变的)。核心接口:Collection、List、Set、Map。

一、集合概述
用来存储不同类型的多个对象的一些特殊类的统称为集合,可以简单的理解为存储不同数据类型的动态数组(因为数组的长度是一定的,而集合长度是可以改变的)。核心接口:Collection、List、Set、Map。

二、Collection接口
Collection接口是Java单列集合中的根接口,在某种定义上可以把Collection看成是动态的数组,一个对象的容器,通常把放入Collection中的对象称为元素。

1.Collection接口的声明
public interface Collection
2.Collection接口的方法
public boolean add(Object o)

功能描述:向当前集合中添加一个元素

public boolean addAll(Collection c)

功能描述:将集合c中所有元素添加给此集合

public void clear()

功能描述:删除集合中的所有元素

public boolean contain(Object o)

功能描述:查找集合中是否含有对象o

public boolean containsAll(Collection c)

功能描述:查找集合中是否含有集合c中的所有元素

public boolean equals(Object o)

功能描述:判断集合是否等价

public boolean isEmpty()

功能描述:判断集合中是否有元素

public boolean remove(Object o)

如果集合中有与o相匹配的对象,就删除对象o

public Iterator iterator()

返回一个迭代器,用于访问集合中的各个元素

public int size()

功能描述:返回当前集合中元素数量

三、List接口
List是Collection的子接口,继承了Collection接口的全部方法,还添加了一些特有方法。

1.List接口的声明
public interface List extends Collection

2.List接口的方法
public void add(int index,Object element)

功能描述:在指定位置index上添加元素element

public Object get(int index)

功能描述:返回列表中指定位置的元素

public int indexOf(Object o)

功能描述:返回第一次出现元素o的位置,否则返回-1

public int indexOf(Object o)

功能描述:返回最后一次出现元素o的位置,否则返回-1

public Object remove(int index)

功能描述:删除指定位置上的元素

public Object set(int index,Object element)

功能描述:用元素element代替index位置上的元素

3.举例
随机生成7个36以内的数并存入list集合中

代码

package test3;
 
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
 
public class test3 {
    public static void main(String[] args) {
        Random r=new Random();
        List<Integer> list=new ArrayList<Integer>();
        int count=0;
        while(count<7) {
            int num=r.nextInt(36)+1;
            if(!list.contains(num)) {
                list.add(num);
                count++;
            }
            }
        System.out.println("36选7摇号如下:");
            for (Integer integer : list) {
                System.out.print(integer+"\t");
            }
        }
}
AI 代码解读

执行结果
image.png

四、Set接口
Set的方法与Collection接口的方法基本一致,Set元素无序且不重复

HashSet
HashSet是Set接口的一个实现类,为了去掉重复元素需要重写hashCode()和equals()方法

举例
随机生成7个36以内的数并存入HashSet集合中

代码

package test8;
 
import java.util.HashSet;
 
public class test8 {
    public static void main(String[] args) {
        HashSet<Integer> set=new HashSet<>();//注意Integer里的I是大写的
        System.out.println("36选7摇号如下:");
        while(set.size()<7) {
            int num=(int)(Math.random()*36)+1;//(int)不要忘记
            set.add(num);
        }
        for (Integer integer : set) {
            System.out.print(integer+"\t");
        }
    }
}
AI 代码解读

执行结果
image.png

相关文章
JUC并发—1.Java集合包底层源码剖析
本文主要对JDK中的集合包源码进行了剖析。
Java 集合面试题 PDF 下载及高频考点解析
本文围绕Java集合面试题展开,详细解析了集合框架的基本概念、常见集合类的特点与应用场景。内容涵盖`ArrayList`与`LinkedList`的区别、`HashSet`与`TreeSet`的对比、`HashMap`与`ConcurrentHashMap`的线程安全性分析等。通过技术方案与应用实例,帮助读者深入理解集合类的特性和使用场景,提升解决实际开发问题的能力。文末附带资源链接,供进一步学习参考。
52 4
现代应用场景中 Java 集合框架的核心技术与实践要点
本内容聚焦Java 17及最新技术趋势,通过实例解析Java集合框架的高级用法与性能优化。涵盖Record类简化数据模型、集合工厂方法创建不可变集合、HashMap初始容量调优、ConcurrentHashMap高效并发处理、Stream API复杂数据操作与并行流、TreeMap自定义排序等核心知识点。同时引入JMH微基准测试与VisualVM工具分析性能,总结现代集合框架最佳实践,如泛型使用、合适集合类型选择及线程安全策略。结合实际案例,助你深入掌握Java集合框架的高效应用与优化技巧。
63 4
Java 集合面试题从数据结构到 HashMap 源码剖析详解及长尾考点梳理
本文深入解析Java集合框架,涵盖基础概念、常见集合类型及HashMap的底层数据结构与源码实现。从Collection、Map到Iterator接口,逐一剖析其特性与应用场景。重点解读HashMap在JDK1.7与1.8中的数据结构演变,包括数组+链表+红黑树优化,以及put方法和扩容机制的实现细节。结合订单管理与用户权限管理等实际案例,展示集合框架的应用价值,助你全面掌握相关知识,轻松应对面试与开发需求。
106 3
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
114 3
|
3月前
|
Java LinkedList集合的深度剖析
总的来说,我希望像说故事一样讲解Java LinkedList集合的使用和实现原理,让有些许枯燥的编程知识变得趣味盎然。在这个“公交车”故事中,你不仅熟悉了LinkedList集合的实现和使用,而且还更深入地理解了数据结构中的链表。链表可能会因为插入和删除的便利性而被选用,虽然它的查找效率并不高,但是在很多场景中仍然十分有效。这就像公交车,虽然它速度不快,但却是城市出行的重要工具。
73 8
|
9月前
|
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
103 3
|
3月前
|
Java 集合框架详解:系统化分析与高级应用
本文深入解析Java集合框架,涵盖List、Set、Map等核心接口及其常见实现类,如ArrayList、HashSet、HashMap等。通过对比不同集合类型的特性与应用场景,帮助开发者选择最优方案。同时介绍Iterator迭代机制、Collections工具类及Stream API等高级功能,提升代码效率与可维护性。适合初学者与进阶开发者系统学习与实践。
95 0
java常见的集合类有哪些
Map接口和Collection接口是所有集合框架的父接口: 1. Collection接口的子接口包括:Set接口和List接口 2. Map接口的实现类主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap以及 Properties等 3. Set接口的实现类主要有:HashSet、TreeSet、LinkedHashSet等 4. List接口的实现类主要有:ArrayList、LinkedList、Stack以及Vector等
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
117 5

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问