Java研学-集合框架

news2024/11/27 22:30:31

一 关于集合框架

1 集合是Java提出的用来进行多个数据存储的"容器",数组也具备这样的功能,

2 由于数组一旦创建长度固定,且只能存放一种数据类型,不够灵活,Java提出更灵活,存放任意的数据类型的容器也就是集合

3 集合和数组的异同点

相同点:都是用来存储多个数据类型的容器

不同点:存储的灵活性

  ① 长度: 数组一旦创建长度固定;集合可以灵活存储

  ② 数据类型: 数据可存放指定的一种数据类型,既可以是基本数据类型也可以是引用数据类型;集合只能存放任意的引用数据类型(如果赋值基本数据类型,底层以基本数据类型的包装类存储,自动装箱的形式完成)

二 集合框架的分类

1 单列集合-将数据进行一个一个的存储

单列表集合类结构图

2 双列集合-基于 Key 与 Value 的结构存储数据

双列集合

3 单列集合存储特点以及具体实现类底层存储

① 存储特点

  Collection接口: 既可以存储重复值,也可以存储不重复值;既可以有序,也可以无序

  List接口: 有序不唯一

  Set接口: 无序且唯一

  Queue接口: 先进先出 队列式存储

② 实现类底层存储模式

  ArrayList类: 底层基于动态数组存储

  LinkedList类: 底层基于双链表存储

  TreeSet类: 底层基于二叉树存储

  HashSet: 底层基于哈希码值存储

三 单列集合

1 ArrayList类

// 可调整大小的数组的实现List接口
Class ArrayList<E>

< E> – 表示泛型

  ① 泛型的含义: 泛指的任意的引用数据类型

  ② 泛型使用的格式: <字母> – 字母一般是任意一个,必须得大写

java中规定的泛型字母含义
EElement,表示集合中存储元素的类型
KKEY,表示Map中键的类型
VVALUE,表示Map集合中值的类型
RResult,表示方法的返回值类型
?表示不确定的任意一种类型
TType,存储的类型

  ③ 使用泛型的好处:提高集合存储数据的安全性;一旦集合使用泛型,等效于数组;实际开发中,一般在集合使用的时候,必须配合泛型使用

2 创建集合

ArrayList对象有初始值;长度是10;可以进行扩容;扩容的倍数是1.5

public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList list=new ArrayList();
        // 直接打印集合对象,显示集合中所有元素
        System.err.println(list);
    }
}

3 增加元素

// 在集合的尾部追加指定的元素
public boolean add(E e)

// 将指定的元素插入到集合的指定位置上
public void add(int index ,E e)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Object> list=new ArrayList<Object>();
        list.add("qq");
        list.add(13);
        list.add(false);
        list.add('@');
        // 指定下标添加元素
        list.add(2,5);
        list.add("qq");
        list.add(0,23);
        System.err.println(list);
        //[23, qq, 13, 5, false, @, qq]
    }
}

4 删除元素

// 清空集合中所有数据,但是保留集合结构
public void clear()
 
// 移除指定位置上的元素,并且返回该元素
public E remove(int index)

// 将指定元素从集合中移除(如果存在)
public boolean remove(E e)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Object> list=new ArrayList<Object>();
        list.add("qq");
        list.add(13);
        list.add(false);
        list.add('@');
        // 指定下标添加元素
        list.add(2,5);
        list.add("qq");
        list.add(0,23);
        System.err.println(list);
        // [23, qq, 13, 5, false, @, qq]
        // 删除指定元素时若元素类型是整数或字符型,需将值传递为元素对象进行删除
        // 因为可能会将传递的值认为是下标,造成数组下标越界
        // 值转对象:类型强转 (包装类)值
        System.err.println("移除元素5"+list.remove((Integer)5));
        // 移除元素5true
        System.err.println(list);
        // [23, qq, 13, false, @, qq] 删除成功返回 true
        System.out.println("移除位置3上的元素:"+list.remove(3));
        // 移除位置3上的元素:false(返回元素本身)
        System.out.println(list);
        list.clear();
        System.out.println("清空后的list"+list);
    }
}

5 修改元素

// 使用指定的元素修改指定位置上的原有元素,将原有的元素返回
public E set(int index,E e )

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Object> list=new ArrayList<Object>();
        list.add("qq");
        list.add(13);
        list.add(false);
        list.add('@');
        // 指定下标添加元素
        list.add(2,5);
        list.add("qq");
        list.add(0,23);
        System.err.println(list);
        // [23, qq, 13, 5, false, @, qq]
        System.out.println("用!替换1位置上的元素"+list.set(1,"!"));
        // 返回指定位置上的元素 用!替换1位置上的元素qq
        System.out.println("替换后"+list);
        // 替换后[23, !, 13, 5, false, @, qq]
    }
}

6 查询元素

// 获取集合指定位置上的元素
public E get(int index)

// 获取指定元素在集合中第一次出现的位置,如果不存在返回-1
public int indexOf(E e)

// 获取指定元素在集合中最后一次出现的位置,如果不存在返回-1
public int lastIndexOf(E e)

// 获取集合元素的真实个数
public int size()

// 获取集合中指定范围内的所有元素,不包含结束位置
public List<E> subList(int beginIndex,int endIndex)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Object> list=new ArrayList<Object>();
        list.add("qq");
        list.add(13);
        list.add(false);
        list.add('@');
        // 指定下标添加元素
        list.add(2,5);
        list.add("qq");
        list.add(0,23);
        System.err.println(list);
        // [23, qq, 13, 5, false, @, qq]
        System.out.println("集合长度"+list.size());
        // 集合长度7
        System.out.println("2位置上的元素"+list.get(2));
        // 2位置上的元素13
        System.out.println("qq第一次出现的位置"+list.indexOf("qq"));
        // qq第一次出现的位置1
        System.out.println("qq最后一次出现的位置"+list.lastIndexOf("qq"));
        // qq最后一次出现的位置6
        System.out.println("[1,3)范围内的元素"+list.subList(1,3));
        // [1,3)范围内的元素[qq, 13]
    }
}

7 判别元素

// 判断指定的元素是否是集合中的元素
public boolean contains(E e)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Object> list=new ArrayList<Object>();
        list.add("qq");
        list.add(13);
        list.add(false);
        list.add('@');
        // 指定下标添加元素
        list.add(2,5);
        list.add("qq");
        list.add(0,23);
        System.err.println(list);
        // [23, qq, 13, 5, false, @, qq]
        System.out.println("@在集合中吗"+list.contains('@'));
        // @在集合中吗true
    }
}

8 Collections类 – 操作所有单列集合工厂类

// 获取指定单列集合中元素的最大值
public static E max(Collection<E> c)

// 获取指定单列集合中元素的最小值
public static E min(Collection<E> c)

// 给指定的List集合进行默认的升序排序
public static void sort(List<E> list)

// 将指定的多个散数据(引用数据类型),同时存放到List 集合中,Arrays类提供
public static List<T>  asList( T ..... t)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        ArrayList<Integer> list=new ArrayList<Integer>();
        list.add(13);
        list.add(7);
        list.add(45);
        list.add(2);
        list.add(2,5);
        list.add(0,23);
        System.err.println(list);
        // [23, 13, 7, 5, 45, 2]
        Collections.sort(list);
        System.out.println("排序后"+list);
        // 排序后[2, 5, 7, 13, 23, 45]
        System.out.println("最大"+Collections.max(list));
        System.out.println("最小"+Collections.min(list));
        // 最大45   最小2
    }
}

// 将任意的多个引用数据类型同时存储在List集合中
public class ArrayListTest {
    public static void main(String[] args) {
        List<Object> list = Arrays.asList("qwer", 'e', 456, Math.PI, true);
        System.err.println(list);
        // [qwer, e, 456, 3.141592653589793, true]
        // list是接口对象,因此不能直接调用接口中的抽象方法完成操作
        // 需将list集合的数据放到ArrayList中,通过ArrayList对象调用方法完成操作
        ArrayList<Object> als=new ArrayList<Object>();
        for (Object o: list) {
            als.add(o);
        }
        als.add("asdwd");
        System.out.println(als);
        // [qwer, e, 456, 3.141592653589793, true, asdwd]
    }
}

9 LinkedList类 – 创建集合

// 双向链表
Class LinkedList<E>

// 创建集合
public LinkedList()

10 LinkedList 与 ArrayList 集合中的一致方法,使用效果也一致,参考ArrayList同名方法

11 增加元素

// 将指定的元素插入到链表的头部
public void addFirst(E e)

//将指定的元素查入到链表的尾部
public void addLast(E e)

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        LinkedList<Integer> ll=new LinkedList<>();
        ll.add(12);
        ll.add(122);
        ll.add(142);
        ll.add(2,22);
        System.err.println(ll);
        // [12, 122, 22, 142]
        ll.addFirst(-11);
        ll.addLast(-22);
        System.err.println(ll);
        // [-11, 12, 122, 22, 142, -22]
    }
}

12 删除元素

// 移除链表中头部位置上的元素
public E removeFirst()

// 移除链表中尾部位置上的元素
public E removeLast()

// 例子
public class ArrayListTest {
    public static void main(String[] args) {
        LinkedList<Integer> ll=new LinkedList<>();
        ll.add(12);
        ll.add(122);
        ll.add(142);
        ll.add(2,22);
        System.err.println(ll);
        // [12, 122, 22, 142]
        ll.removeFirst();
        System.err.println(ll);
        // [122, 22, 142]
    }
}

四 java的数据存储方式

1 数据存储方式:实质上就是集合型数据在jvm虚拟机中存取的操作

2 分类

① 队列式存储: 先进先出,类似于吸管

  存: LinkedList类 – addFirst()

  取: LinkedList类 – removeLast()

② 堆栈式存储 : 先进后出

  存:LinkedList类中 – addFirst()

  取:LinkedList类中 – removeFirst()

代码演示 – 堆栈内存存储方式
public class PriStack<T> {
    // 定义私有化变量LinkedList
    private LinkedList<T> ll;

    // 定义当前类有参构造器,参数是用户传递的LinkedList对象
    public PriStack(LinkedList<T> ll){
        this.ll=ll;
    }

    // 存数据
    public void save(T t){
        ll.addFirst(t);
    }

    // 取数据
    public T gain(){
        return ll.removeFirst();
    }

    // 显示集合元素
    public void show(){
        System.err.println(ll);
    }

    // 取元素个数
    public int size(){
        return ll.size();
    }
}

public class PriStackTest {
    public static void main(String[] args) {
        PriStack<String> ps=new PriStack<String>(new LinkedList<String>());
        ps.save("this a");
        ps.save("this b");
        ps.save("this c");
        ps.show();
        // [this c, this b, this a]
        while (ps.size()>0){
            System.out.println(ps.gain());
        }
        //this c
        //this b
        //this a
    }
}

3 泛型的应用

  ① 泛型可以使用的位置 : 类 和 类成员 (一般成员方法)

  ② 泛型使用的前提: 定义的类或类成员完成对数据的存取操作时

五 HashSet类

1 创建对象

// 此类实现Set接口
public class HashSet<E>

// 创建对象
public HashSet()

2 Set集合是无序的散列表,元素的位置相对不稳定,故Set集合中摒弃List集合中所有有关位置的方法,没有关于位置操作的方法;其余与List同名方法参照List集使用

public class play {
    public static void main(String[] args) {
        HashSet<Object> hs=new HashSet<>();
        hs.add("132");
        hs.add(213);
        hs.add('*');
        hs.add("dw");
        hs.add(5.5);
        System.out.println(hs);
        // [132, dw, 213, 5.5, *]
    }
}

3 例子

// 向集合存放十个数,以升序排序的方式显示,同时显示最大最小值
public class play {
    public static void main(String[] args) {
        ArrayList<Integer> list=new ArrayList<Integer>();
        for (int i = 0; i < 10; i++) {
            // 注意优先级问题
            list.add((int)(Math.random()*100));
        }
        System.err.println("排序前"+list);
        Collections.sort(list);
        System.err.println("排序后"+list);
        System.err.println(Collections.max(list));
        System.err.println(Collections.min(list));
    }
}

// 方式二
public class play {
    public static void main(String[] args) {
        HashSet<Integer> hashSet=new HashSet<Integer>();
        while (hashSet.size()<10){
            hashSet.add((int) (Math.random()*100));
        }
        System.err.println(hashSet);
        System.err.println(Collections.max(hashSet));
        System.err.println(Collections.min(hashSet));
    }
}

六 迭代器

1 迭代表示产品的更新换代,在集合中所谓的迭代就是操作(存和取)指定集合中的元素

2 数组对于元素的存取操作的方式

① 存

for(int i=0;i<数组名.length;i++){
    数组名[i]=;
}

② 取

//当需要操作元素下标的时候 -- 使用普通for循环
for(int 1=0; i<数组名.length;i++){
    变量=数组名[i];
}
//当需要直接操作数组元素的时候 -- 使用增强for (forEach)
for(数据类型 变量名 : 数组名){
    操作变量;
}

3 对于List集合-单列集合元素存取操作

① 存数据 – 普通for循环

for(int i = 0; i<数值;i++){
    集合对象名.add(E e);
}
//推荐使用while原因集合长度不限,因此很少指定长度
while(true){
    集合对象名.add(E e);
    if(判断条件){
        break;
    }
}

② 取数据

//方式一:根据元素下标获取元素 普通for
for(int i= 0 ;i<集合对象名.size();i++){
    对象=集合对象名.get(i);
}
//方式二:直接操作元素 增强for
for(类 对象 : 集合名){
    操作对象;
}
//方式三: 迭代器,java封装好的一个接口Iterator迭代接口
Iterator<集合泛型的类型> it = 集合对象名.iterator();//获取迭代器对象
while(it.hasNext()){//判断下一个位置是还有元素
    对象=it.next();//获取集合中的元素
}

4 Set集合中对元素的存和取操作

① 存数据

//由于Set集合没有位置,因此只能使用while循环添加数据
while(true){
    集合对象名.add(E e);
    if(判断条件){
        break;
    }
}

② 取数据

for(类 对象: 集合名){
    操作对象;
}

5 关于迭代器(单列)

hasNext方法的详解 – 游标指针操作原理

  通过集合对象获取迭代器对象,通过迭代器对象调用hasNext(),此时游标指针创建,默认停放的位置是-1,表示没有获取到元素;通过while循环启动游标指针,在指定的单列集合中移动
  在迭代器中对该方法限定移动范围[0,集合对象名.size())

例子
// 迭代器只操作单列集合
public class play {
    public static void main(String[] args) {
        HashSet<Integer> hashSet=new HashSet<Integer>();
        while (hashSet.size()<10){
            hashSet.add((int) (Math.random()*100));
        }
        System.err.println(hashSet);
        // 通过单列集合对象调用iterator()方法获取迭代器对象,有迭代器对象才能调用迭代器方法
        Iterator<Integer> it=hashSet.iterator();
        // 通过迭代器对象调用方法,判断集合中下一个位置上是否还有元素,有则继续
        while (it.hasNext()){
            // 元素存在,通过迭代器对象获取元素赋值给i,显示
            Integer i=it.next();
            // 显示大于60的元素
            if(i>60){
                System.err.println(i);
            }
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1259445.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

西南科技大学数字电子技术实验一(数字信号基本参数与逻辑门电路功能测试及FPGA 实现 )预习报告

手写报告稍微认真点写,80+随便有 目录 一、计算/设计过程 1、通过虚拟示波器观察和测量信号 2、通过实际电路(电阻、开关、发光二极管)模拟逻辑门电路 二、画出并填写实验指导书上的预表

ELK----日志分析

ELK相关知识 ELK的概念与组件 ELK平台是一套完整的日志集中处理解决方案&#xff0c;将 ElasticSearch、Logstash 和 Kiabana 三个开源工具配合使用&#xff0c; 完成更强大的用户对日志的查询、排序、统计需求。 E&#xff1a;ElasticSearch &#xff08;ES&#xff09; ES是…

智能电表——电源应用

作为智能电网的重要组成部分&#xff0c;智能电表在智能电网中发挥着不可或缺的作用。智能电表是指以智能芯片为核心&#xff0c;通过运用通讯技术以及计算机技术等&#xff0c;能够进行电能计费、电功率的计量和计时&#xff0c;并且能够和上位机进行通讯、用电管理的电度表。…

STK Components 二次开发- 区域

1.创建区域 需要提供点坐标。最少三个点可以确定一个区域。 创建区域也是一样&#xff0c;创建对象然后设置点位置 &#xff0c;然后设置区域属性。 var referenceSurface m_earth.Shape; // We specify the boundary in terms of nodes connected by geodesics.var result…

PlantUML语法(全)及使用教程-时序图

目录 1. 参与者1.1、参与者说明1.2、背景色1.3、参与者顺序 2. 消息和箭头2.1、 文本对其方式2.2、响应信息显示在箭头下面2.3、箭头设置2.4、修改箭头颜色2.5、对消息排序 3. 页面标题、眉角、页脚4. 分割页面5. 生命线6. 填充区设置7. 注释8. 移除脚注9. 组合信息9.1、alt/el…

卷积神经网络(CNN)识别神奇宝贝小智一伙

文章目录 一、前言二、前期工作1. 设置GPU&#xff08;如果使用的是CPU可以忽略这步&#xff09;2. 导入数据3. 查看数据 二、数据预处理1.加载数据2. 可视化数据4. 配置数据集 三、调用官方网络模型四、设置动态学习率五、编译六、训练模型七、模型评估八、保存and加载模型九、…

Linux网络——数据链路层

目录 一.认识以太网 二.以太网帧格式 三.认识MAC地址 四.认识MTU 五.以太局域网的通信原理 六.其他重要协议 1.DNS协议 2.域名简介 3.ICMP协议 4.NAT技术 5.NAT技术的缺陷 6.NAT和代理服务器 一.认识以太网 "以太网" 不是一种具体的网络, 而是一种技术标…

C语言入门---位操作

目录 1. 两个数不同的二进制位个数 2.原码、反码、补码 3.不创建临时变量实现两个数的交换 4.求一个整数存储在内存中的二进制中1的个数 5. 特例-1 6.将指定的位置置1 7.将指定位置置1 8.a与a 9.||与&& 10.逗号表达式 11.srand与rand 12.sizeof 13.结构体初始…

一文了解低代码平台

随着数字化转型的加速&#xff0c;企业需要更快速地开发和交付应用程序&#xff0c;以适应市场需求和客户需求的变化。在这种情况下&#xff0c;低代码平台成为了企业的首选方案之一。 想象一下&#xff0c;你可以用一个可视化工具构建自己的应用程序&#xff0c;而无需编写繁琐…

保护IP地址不被窃取的几种方法

随着互联网的普及和信息技术的不断发展&#xff0c;网络安全问题日益凸显。其中&#xff0c;保护个人IP地址不被窃取成为了一个重要的问题。IP地址是我们在互联网上的身份标识&#xff0c;如果被他人获取&#xff0c;就可能导致个人隐私泄露、计算机受到攻击等一系列问题。因此…

你“瞧不起”的拼多多,原来还有这样的一面

有人说&#xff0c;自私是天性&#xff0c;刻印在基因里的本能。也有人持不同意见。 人类学家玛格丽特米德在授课中问学生&#xff0c;文明最早的标志是什么&#xff1f;有人说是陶罐&#xff0c;石器&#xff0c;或者武器&#xff0c;米德告诉他们&#xff0c;是一根愈合的股…

python scoket 多人聊天室 带界面

前言 本来是为了局域网内能够复制段儿代码方便远程调试用的&#xff0c;ssh当然也可以&#xff0c;当然还是我头脑风暴散发&#xff0c;想到这里了。于是从网上拉了一个&#xff0c;改通之后&#xff0c;留一个备份。 期望还是很好的&#xff0c;以后用来支持ubuntu聊天之类的…

新能源钠离子电池污废水如何处理

钠离子电池作为一种新能源电池&#xff0c;已经展示出了广阔的应用前景。然而&#xff0c;随着其生产和使用规模的不断扩大&#xff0c;对其产生的污废水问题也变得越来越重要。如何处理新能源钠离子电池的污废水&#xff0c;已经成为一个必须解决的问题。 首先&#xff0c;我…

第二十五章 解析cfg文件及读取获得网络结构

网络结构 以YOLOv3_SPP为例 cfg文件 部分&#xff0c;只是用来展示&#xff0c;全部的代码在文章最后 [net] # Testing # batch1 # subdivisions1 # Training batch64 subdivisions16 width608 height608 channels3 momentum0.9 de…

基于STM32 +(NVIC)中断概念应用和控制方案

前言 本次我们学习一下STM32的中断控制器—— NVIC&#xff0c;控制着整个STM32芯片中断相关的功能&#xff0c;它跟Cortex-M3 内核紧密联系&#xff0c;是内核里面的一个外设。 本篇博客大部分是自己收集和整理&#xff0c;借鉴了很多大佬的图片和知识点整理&#xff0c;如有侵…

中科大蒋彬课题组开发 FIREANN,分析原子对外界场的响应

内容一览&#xff1a; 使用传统方法分析化学系统与外场的相互作用&#xff0c;具有效率低、成本高等劣势。中国科学技术大学的蒋彬课题组&#xff0c;在原子环境的描述中引入了场相关特征&#xff0c;开发了 FIREANN&#xff0c;借助机器学习对系统的场相关性进行了很好的描述。…

一文读懂:IOPS、延迟和吞吐量等存储性能指标

各位ICT的小伙伴们大家好呀&#xff0c; 在我们谈存储性能的时候&#xff0c;总会听到IOPS、延迟&#xff08;Latency&#xff09;、带宽&#xff08;Bandwidth&#xff09;、吞吐量&#xff08;Throughput&#xff09;以及响应时间&#xff08;Response Time&#xff09;等技…

Lighthouse(灯塔)—— Chrome浏览器强大的性能测试工具

本文浏览器版本参考如下&#xff1a; 一、认识Lighthouse Lighthouse 是 Google 开发的一款工具&#xff0c;用于分析网络应用和网页&#xff0c;收集现代性能指标并提供对开发人员最佳实践的意见。 为 Lighthouse 提供一个需要审查的网址&#xff0c;它将针对此页面运行一连…

Typora+PicGo+Minio搭建博客图床

文章目录 TyporaPicGoMinio搭建博客图床前言什么是图床?为什么需要图床?准备工作一、Typora二、Picgo1. 下载Picgo2. 下载node.js3. 下载minio插件 三、服务器端配置1. 添加端口到安全组2. 使用Docker安装minio3. 配置minio image-20231127175530696四、minio插件配置五、Typ…

Python入门04字符串

目录 1 字符串的定义2 转义字符3 字符串的常见方法4 分割字符串5 字符串反转6 字符串的链式调用7 格式化字符串8 多行字符串总结 1 字符串的定义 在Python中&#xff0c;字符串表示一个字符的序列&#xff0c;比如 str "hello,world"这里我们定义了一个字符串&…