【Java百炼成神】大魂师进阶篇——ArrayList、LinkedList、Vector、HashSet

简介: 【Java百炼成神】大魂师进阶篇——ArrayList、LinkedList、Vector、HashSet

ArrayList


ArrayList简介


ArrayList 是开发中最常用的集合

该集合因为使用索引,查找速度极快。

用于进行数据存储和数据的获取、遍历

image.png

练习:

1、定义集合存放多个整数,打印集合中所有整数的和,最大值,最小值。

2、定义集合,存储多个员工(包含姓名、月工资),计算公司一个月所有员

工工资的总支出。


增强for循环


实际开发中,由于迭代器操作繁琐,所以最常使用的是 foreach 循环(又叫增强 for 循环)来完成元素的

获取,增强 for 循环是完成集合迭代的简化方式。


//增强 for 循环格式如下: 
for(元素数据类型 变量:容器 or 数组) { 
 //循环体,变量中存放内容就相当于 it.next()获得内容 
}

微信图片_20220529232356.png

并发修改异常


尝试完成以下练习:

定义集合存储 4 个字符串分别为:”abc1”, ”abc2”, ”abc3”, ”abc4”,使用增强 for 遍历集合,获取每一个

元素,判断如果包含”abc2”这个元素,则添加一个元素”czxy”

有部分同学会出现代码异常:微信图片_20220529232403.png

这是就是并发修改异常。

并发就是同时的意思,好比是一个小门,一个人进门一个人出门,那么他们进出门的行为就是同时进

行,我们称为并发。


出现原因:

迭代过程中并发修改异常的原因为迭代器中”记忆”的集合长度与集合中实际长度不同,而导致出现索

引与实际元素不符甚至无限循环的情况发生。

所以在使用增强 for 时,我们要尽量避免在遍历过程中为集合添加/删除数据,


解决方案:

普通 for: 遍历时,可以进行添加/删除操作。

增强 for: 仅仅做遍历,不会在遍历中 添加/删除 集合元素


练习:

集合中存储多个 Person(姓名、年龄、性别、描述)对象,将集合中年龄大于 80 岁的 Person 对象

删除。


LinkedList


LinkedList 叫做链表:微信图片_20220529232411.png

LinkedList 与 ArrayList 的创建方式相似:微信图片_20220529233126.png

但 API 方法却完全不同:

image.png微信图片_20220529232422.png

注意:

虽然 LinkedList 可以像 ArrayList 那样通过索引来获取/删除元素:

例如:get(索引)/remove(索引) 微信图片_20220529232436.png

总结:

需要一次性保存大量数据,经常进行索引遍历数据,推荐使用 ArrayList

需要进行数据频繁的追加和删除,极少使用索引遍历数据,推荐使用 LinkedList


练习:

1、公司新闻公告,需要频繁滚动新闻(添加新新闻,但每次只展示前 4 条新

闻)。请选择合适的集合,存储新闻(String 信息),并打印前 4 条。

2、定义 LinkedList 集合,存储多个员工 Employee(包含姓名、工资),

该集合我们就可以理解为一个公司。

集合中有如下数据:

张三,10000

李四,9000

王五,8000

现在要在张三前面添加一个员工:牛二,15000

开除最后一个员工:王五

操作完成后,计算该公司一个月所有员工工资的总支出。


Vector简介


Vector:我们可以将其理解为版本旧的、安全的、效率低的 ArrayList,Vector 中提供了一个独特的取

出方式,返回 Enumeration。此接口 Enumeration 的功能与 Iterator 接口的功能是类似的。

 image.png微信图片_20220529233508.png

微信图片_20220529233534.png

HashSet


HashSet 集合不能存放重复元素。

如:

居民身份证号、商品货号等。

 

注:

HashSet 集合无索引。

HashSet 集合迭代元素的顺序与存储元素的顺序无关

常用方法:

image.png

因为无索引,所以 HashSet 无通过索引单独获取某个元素的常规方法微信图片_20220529232453.png

练习:

1、定义一个整数数组

int[] arr = {11,22,33,44,55,33,22,11};

使用 HashSet 集合取出数组中重复的数字,并将重复数字保存到一个

ArrayList 集合中。

相关文章
|
2月前
|
Java 索引 容器
Java ArrayList扩容的原理
Java 的 `ArrayList` 是基于数组实现的动态集合。初始时,`ArrayList` 底层创建一个空数组 `elementData`,并设置 `size` 为 0。当首次添加元素时,会调用 `grow` 方法将数组扩容至默认容量 10。之后每次添加元素时,如果当前数组已满,则会再次调用 `grow` 方法进行扩容。扩容规则为:首次扩容至 10,后续扩容至原数组长度的 1.5 倍或根据实际需求扩容。例如,当需要一次性添加 100 个元素时,会直接扩容至 110 而不是 15。
Java ArrayList扩容的原理
|
2月前
|
存储 Java 索引
Java中的数据结构:ArrayList和LinkedList的比较
【10月更文挑战第28天】在Java编程世界中,数据结构是构建复杂程序的基石。本文将深入探讨两种常用的数据结构:ArrayList和LinkedList,通过直观的比喻和实例分析,揭示它们各自的优势与局限,帮助你在面对不同的编程挑战时做出明智的选择。
|
3月前
|
安全 Java 程序员
Java集合之战:ArrayList vs LinkedList,谁才是你的最佳选择?
本文介绍了 Java 中常用的两个集合类 ArrayList 和 LinkedList,分析了它们的底层实现、特点及适用场景。ArrayList 基于数组,适合频繁查询;LinkedList 基于链表,适合频繁增删。文章还讨论了如何实现线程安全,推荐使用 CopyOnWriteArrayList 来提升性能。希望帮助读者选择合适的数据结构,写出更高效的代码。
109 3
|
3月前
|
机器学习/深度学习 算法 Java
通过 Java Vector API 利用 SIMD 的强大功能
通过 Java Vector API 利用 SIMD 的强大功能
89 10
|
3月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
43 0
|
Java
Java HashSet LinkedHashSet TreeSet类源码解析
Set集合中不含有重复的元素,插入重复的元素会失败。常用的有HashSet LinkedHashSet TreeSet。HashSet是无序的集合,LinkedHashSet中的排序和插入成功的顺序一致重复插入,TreeSet中元素是有序排列的,排序的依据是自身的comparator如果为null则根据key从小到大排序。
2197 0
|
Java 算法
HashSet源码解析(基于Java8)
List保证元素的添加顺序,元素可重复 Set不保证元素的添加顺序,元素不可重复 public class Test { public static void main(String[] arg...
1126 0
|
Java 索引 算法
Java HashSet源码解析
本解析源码来自JDK1.7,HashSet是基于HashMap实现的,方法实现大都直接调用HashMap的方法 另一篇HashMap的源码解析文章 概要 实现了Set接口,实际是靠HashMap实现的 不保证遍历时的顺...
896 0
|
Java API
Java 集合系列16之 HashSet详细介绍(源码解析)和使用示例
概要 这一章,我们对HashSet进行学习。我们先对HashSet有个整体认识,然后再学习它的源码,最后再通过实例来学会使用HashSet。内容包括:第1部分 HashSet介绍第2部分 HashSet数据结构第3部分 HashSet源码解析(基于JDK1.6.0_45)第4部分 HashSet遍历方式第5部分 HashSet示例 转载请注明出处:http://www.cnblogs.com/skywang12345/p/3311252.html   第1部分 HashSet介绍 HashSet 简介 HashSet 是一个没有重复元素的集合。
1048 0
|
11天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者