当前位置: 首页 > news >正文

JAVA高级第一章 集合框架和泛型(一)

1.为什么使用集合框架

  • 存储一个班学员信息,假定一个班容纳20名学员
    在这里插入图片描述
  • 如何存储每天的新闻信息?

在这里插入图片描述
每天的新闻总数不确定,太少浪费空间,太多空间不足

  • 如何存储课工场课程的代码与课程信息,能够通过代码方便地获得课程信息?
    在这里插入图片描述
  • 如果并不知道程序运行时会需要多少对象,或者需要更复杂方式存储对象——可以使用Java集合框架

2.Java集合框架包含的内容

Java集合框架提供了一套性能优良、使用方便的接口和类,它们位于java.util包中
在这里插入图片描述
在这里插入图片描述

  • Collection 接口存储一组不唯一,无序的对象

在这里插入图片描述

  • List 接口存储一组不唯一,有序(插入顺序)的对象
    在这里插入图片描述
  • Set 接口存储一组唯一,无序的对象
    在这里插入图片描述
    Map接口存储一组键值对象,提供key到value的映射

3.List接口的实现类

在这里插入图片描述

  • ArrayList实现了长度可变的数组,在内存中分配连续的空间,遍历元素和随机访问元素的效率比较高
    在这里插入图片描述
  • LinkedList采用链表存储方式,插入、删除元素时效率比较高

4.ArrayList集合类

新闻管理系统,需求如下

  • 可以存储各类新闻标题(包含ID、名称、创建者)
  • 可以获取新闻标题的总数
  • 可以逐条打印每条新闻标题的名称
    在这里插入图片描述
    确定存储方式
  • ArrayList类是List接口的一个具体实现类
  • ArrayList对象实现了可变大小的数组
  • 随机访问和遍历元素时,它提供更好的性能
    确定存储对象
  • 创建类型:新闻标题
  • 包含属性: ID、名称、创建者

5.ArrayList常用方法

在这里插入图片描述

6.LinkedList集合类

新闻管理系统,需求如下
可以添加头条新闻标题
获取头条和最末条新闻标题
可以删除末条新闻标题
在这里插入图片描述

  • 确定存储方式
  • LinkedList类是List接口的一个具体实现类
  • LinkedList 类用于创建链表数据结构
  • 插入或者删除元素时,它提供更好的性能

7.LinkedList常用方法

在这里插入图片描述

8.Set接口

  • Set接口存储一组唯一,无序的对象
  • HashSet是Set接口常用的实现类
  • Set中存放对象的引用
Set set=new HashSet();
String s1=new String("java");
String s2=s1;
String s3=new String("JAVA");
set.add(s1);
set.add(s2);
set.add(s3);
System.out.println(set.size());

Set接口如何判断加入对象是否已经存在呢?
采用对象的equals()方法比较两个对象是否相等

Set set=new HashSet();
String s1=new String("java");
String s2=s1;
String s3=new String ("java");
set.add(s1);
set.add(s2);
set.add(s3);
System.out.println(set.size());

HashSet是Set接口常用的实现类

Set newsTitleSet = new HashSet();
NewTitle car = new NewTitle(1, "汽车", "管理员");
//增加元素
newsTitleSet.add(car);
//获取元素个数
System.out.println("新闻标题数目为:" + newsTitleList.size() + "条");

Set接口不存在get()方法

8.迭代器Iterator

如何遍历Set集合呢?

  • 方法1:通过迭代器Iterator实现遍历

获取Iterator :Collection 接口的iterator()方法
Iterator的方法
boolean hasNext(): 判断是否存在另一个可访问的元素
Object next(): 返回要访问的下一个元素

  • 方法2:增强型for循环
http://www.lryc.cn/news/588976.html

相关文章:

  • Ubuntu18.04 系统重装记录
  • 写作词汇积累(A):自洽、自恰、恰如其分、恰当
  • MQ2烟雾传感器模块(第九天)
  • C++学习笔记五
  • 《时间简史》:窥探宇宙的奥秘
  • IOS 18下openURL 失效问题
  • 032_API参考文档
  • 前端面试专栏-工程化:25.项目亮点与技术难点梳理
  • 区块链的三种共识机制——PoW、PoS和DPoS原理
  • 数据库第二次作业
  • 【Python练习】044. 编写一个函数,实现快速排序算法
  • 本地电脑安装Dify|内网穿透到公网
  • 开源AI应用开发平台Dify系列(一)
  • YOLO融合CFFormer中的FeatureCorrection_s2c模块
  • 多租户SaaS系统中设计安全便捷的跨租户流程共享
  • 遥感数据与作物生长模型同化及在作物长势监测与估产中的应用
  • 弗兰肯斯坦式的人工智能与GTM策略的崩溃
  • 运维效率提升利器:grep、sed、awk详解与实战练习指南
  • (LeetCode 面试经典 150 题) 383. 赎金信 (哈希表)
  • AR眼镜:重塑医学教育,开启智能教学新时代
  • 配置使用SSH与VScode进行连接
  • dockerfile 最佳实践
  • 如何解决服务器频繁重启的问题?
  • 流媒体直播分发服务器
  • 基于深度学习的LSTM、GRU对大数据交通流量分析与预测的研究
  • Python初学者笔记第十二期 -- (集合与字典编程练习题)
  • 信息学奥赛一本通 1552:【例 1】点的距离
  • 短剧小程序的「技术革命」:从「粗放生长」到「精准运营」
  • MySQL中的“引擎“是什么意思
  • 【算法-BFS 解决最短路问题】探索BFS在图论中的应用:最短路径问题的高效解法