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

Java ArrayList集合和HashSet集合详解

ArrayList集合

概念

ArrayList是Java集合框架中的一个动态数组实现,它继承了AbstractList类并实现了List接口。ArrayList允许存储重复元素,并且维护元素的插入顺序。

创建ArrayList集合类型对象

// 创建空的ArrayList
ArrayList<String> list1 = new ArrayList<String>();// 创建带有初始容量的ArrayList
ArrayList<Integer> list2 = new ArrayList<Integer>(20);// 从其他集合创建ArrayList
List<String> existingList = Arrays.asList("A", "B", "C");
ArrayList<String> list3 = new ArrayList<String>(existingList);

<>表示集合中存储的数据类型(泛型)。想要使集合能够支持所有类型的数据(包括小数、整数、字符串等),可以使用<Object>。需要注意的是,集合类型仅支持引用类型,基本数据类型如int不可直接使用,必须通过其包装类Integer来实现。

添加数据

ArrayList<String> fruits = new ArrayList<String>();
// 添加单个元素
fruits.add("Apple");
fruits.add("Banana");// 在指定位置插入元素
fruits.add(1, "Orange");// 批量添加集合元素  
List<String> additionalFruits = Arrays.asList("Grapes", "Mango");  //先创建一个列表additionalFruits将值存在里面
fruits.addAll(additionalFruits);//再用列表中的值添加到集合的元素

访问数据

// 根据索引获取元素
String firstFruit = fruits.get(0);// 遍历ArrayList
for(String fruit : fruits) {System.out.println(fruit);
}// 使用迭代器
Iterator<String> it = fruits.iterator();
while(it.hasNext()) {System.out.println(it.next());
}

删除数据

// 根据索引删除
fruits.remove(0);// 根据对象删除
fruits.remove("Banana");// 删除所有元素
fruits.clear();// 条件删除
fruits.removeIf(fruit -> fruit.startsWith("A"));

判断集合是否为空

if(fruits.isEmpty()) {System.out.println("集合为空");
}

判断集合是否包含指定的数据

if(fruits.contains("Apple")) {System.out.println("包含苹果");
}

应用案例

// 学生成绩管理系统
ArrayList<Integer> scores = new ArrayList<Integer>();
scores.add(85);
scores.add(90);
scores.add(78);// 计算平均分
double sum = 0;
for(int score : scores) {sum += score;
}
double average = sum / scores.size();
System.out.println("平均分: " + average);

HashSet集合

概念

HashSet是Java集合框架中Set接口的一个实现,它使用哈希表存储元素。HashSet不允许重复元素,不保证元素的插入顺序,允许包含null值。

创建HashSet集合类型对象

// 创建空HashSet
HashSet<String> set1 = new HashSet<String>();// 创建带有初始容量的HashSet
HashSet<Integer> set2 = new HashSet<Integer>(20);// 从其他集合创建HashSet
List<String> list = Arrays.asList("A", "B", "C");
HashSet<String> set3 = new HashSet<String>(list);

<>表示集合中存储的数据类型(泛型)。想要使集合能够支持所有类型的数据(包括小数、整数、字符串等),可以使用<Object>。需要注意的是,集合类型仅支持引用类型,基本数据类型如int不可直接使用,必须通过其包装类Integer来实现。

添加数据

HashSet<String> colors = new HashSet<String>();
colors.add("Red");
colors.add("Green");
colors.add("Blue");// 添加重复元素会被忽略
colors.add("Red"); // 不会添加

访问数据

// HashSet没有get方法,需要遍历
for(String color : colors) {System.out.println(color);
}// 使用迭代器
Iterator<String> it = colors.iterator();
while(it.hasNext()) {System.out.println(it.next());
}

删除数据

// 删除指定元素
colors.remove("Green");// 删除所有元素
colors.clear();

判断集合是否为空

if(colors.isEmpty()) {System.out.println("集合为空");
}

判断集合是否包含指定的数据

if(colors.contains("Blue")) {System.out.println("包含蓝色");
}

HashSet集合转换为数组

// 转换为Object数组
Object[] colorArray = colors.toArray();// 转换为指定类型数组
String[] colorStringArray = colors.toArray(new String[0]);

应用案例

// 网站用户注册系统,确保用户名唯一
HashSet<String> usernames = new HashSet<String>();
usernames.add("user1");
usernames.add("user2");// 检查新用户名是否可用
String newUsername = "user1";
if(usernames.contains(newUsername)) {System.out.println("用户名已存在");
} else {usernames.add(newUsername);System.out.println("注册成功");
}

ArrayList集合和HashSet集合的异同

相同点

  1. 都是Java集合框架的一部分
  2. 都实现了Collection接口
  3. 都允许添加、删除、检查元素是否存在等基本操作
  4. 都支持迭代器遍历

不同点

特性ArrayListHashSet
允许重复元素
维护插入顺序
查找性能O(n) 线性查找O(1) 哈希查找
添加性能O(1) 末尾添加,O(n)中间插入O(1)
删除性能O(n)O(1)
内存使用更高效需要额外内存维护哈希表
元素访问通过索引只能通过遍历或迭代器
实现接口ListSet
线程安全性非线程安全非线程安全
排序支持保持插入顺序无序

选择建议

  • 如果需要维护插入顺序或允许重复元素,使用ArrayList
  • 如果需要快速查找、删除或确保元素唯一性,使用HashSet
  • 如果既需要List特性又需要Set特性,可以考虑LinkedHashSet(维护插入顺序的Set)
http://www.lryc.cn/news/573381.html

相关文章:

  • 【论文笔记】【强化微调】TinyLLaVA-Video-R1:小参数模型也能视频推理
  • 人人都是音乐家?腾讯开源音乐生成大模型SongGeneration
  • 旧物回收小程序开发:开启绿色生活新方式
  • Python列表常用操作方法
  • 从语义到推荐:大语言模型(LLM)如何驱动智能选车系统?
  • 首页实现多级缓存
  • AWS-SAA 第二部份:安全性和权限管理
  • 《map和set的使用介绍》
  • Linux TCP/IP协议栈中的TCP输入处理:net/ipv4/tcp_input.c解析
  • TCP 三次握手与四次挥手全流程详解
  • 【智能体】n8n聊天获取链接后爬虫知乎
  • 设计模式精讲 Day 9:装饰器模式(Decorator Pattern)
  • 【RTP】基于mediasoup的RtpPacket的H.264打包、解包和demo 1:不含扩展
  • 2D曲线点云平滑去噪
  • 雨声_锦程_时年
  • linux生产环境下根据关键字搜索指定日志文件命令
  • 软件工程期末试卷选择题版带答案(共214道)
  • 借助ChatGPT快速开发图片转PDF的Python工具
  • Java大厂面试攻略:Spring Boot与微服务架构深度剖析
  • `shallowReactive` 与 `shallowRef`:浅层响应式 API
  • 网络编程及原理(六):三次握手、四次挥手
  • .Net Core 获取与bin目录相同文件路径的文件
  • MinIO入门教程:从零开始搭建方便快捷的分布式对象存储服务
  • verilog HDLBits刷题“Module addsub”--模块 addsub---加法器-减法器
  • python版halcon环境配置
  • 59-Oracle 10046事件-知识准备
  • 1.23Node.js 中操作 mongodb
  • Django中为api自定义一些装饰器:如参数校验等
  • 获取 Git 仓库
  • npm包冲突install失败