Java集合框架详解:深入探讨Java中的集合框架

前言

Java集合框架是Java语言中用于存储和操作大量数据的基石。集合框架提供了一套灵活的接口和实现,使得数据的存储、访问和管理变得异常简单。在本专栏中,我们将深入探讨Java集合框架,包括List、Set、Map等集合的使用和内部实现。

集合框架概述

Java集合框架主要由以下几个部分组成:

  • 接口(Interfaces):定义了集合的基本操作。
  • 实现(Implementations):提供了接口的具体实现。
  • 算法(Algorithms):用于操作或返回集合的实用方法。

List接口

List是Java集合框架中一个非常重要的接口,它是一个有序的集合,可以包含重复的元素。

List接口的特点

  • 有序:元素按照添加的顺序排列。
  • 可重复:可以包含重复的元素。
  • 动态数组:通常使用动态数组来实现。

List接口的实现

  • ArrayList:基于动态数组实现的List,支持快速随机访问。
  • LinkedList:基于双向链表实现的List,支持快速的插入和删除操作。

示例代码:ArrayList的使用

import java.util.ArrayList;public class ArrayListExample {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("Java");list.add("Python");list.add("C++");System.out.println("Original List: " + list);// Accessing elements by indexSystem.out.println("Element at index 1: " + list.get(1));// Removing elementslist.remove("C++");System.out.println("List after removal: " + list);}
}

示例代码:LinkedList的使用

import java.util.LinkedList;public class LinkedListExample {public static void main(String[] args) {LinkedList<String> list = new LinkedList<>();list.add("Java");list.addFirst("Python");list.addLast("C#");System.out.println("Original List: " + list);// Accessing elementsSystem.out.println("First Element: " + list.getFirst());System.out.println("Last Element: " + list.getLast());// Removing elementslist.removeFirst();list.removeLast();System.out.println("List after removal: " + list);}
}

Set接口

Set是一个不允许重复元素的集合。

Set接口的特点

  • 不允许重复:不能包含重复的元素。
  • 无序:元素没有特定的顺序。

Set接口的实现

  • HashSet:基于哈希表实现的Set,提供快速查找。
  • LinkedHashSet:类似于HashSet,但可以按照插入顺序遍历元素。
  • TreeSet:基于红黑树实现的Set,可以按照自然顺序或自定义顺序排序元素。

示例代码:HashSet的使用

import java.util.HashSet;public class HashSetExample {public static void main(String[] args) {HashSet<Integer> set = new HashSet<>();set.add(1);set.add(2);set.add(3);System.out.println("Original Set: " + set);// Checking for existenceSystem.out.println("Does the set contain 2? " + set.contains(2));// Removing elementsset.remove(2);System.out.println("Set after removal: " + set);}
}

示例代码:LinkedHashSet的使用

import java.util.LinkedHashSet;public class LinkedHashSetExample {public static void main(String[] args) {LinkedHashSet<String> set = new LinkedHashSet<>();set.add("Java");set.add("Python");set.add("C++");System.out.println("Original Set: " + set);// Iterating in insertion orderset.forEach(element -> System.out.println(element));}
}

示例代码:TreeSet的使用

import java.util.TreeSet;public class TreeSetExample {public static void main(String[] args) {TreeSet<Integer> set = new TreeSet<>();set.add(3);set.add(1);set.add(2);System.out.println("Sorted Set: " + set);// TreeSet maintains natural orderingset.forEach(element -> System.out.println(element));}
}

Map接口

Map是一种键值对集合,每个键只能映射一个值。

Map接口的特点

  • 键值对:存储数据为键值对的形式。
  • 键唯一:每个键都是唯一的。

Map接口的实现

  • HashMap:基于哈希表实现的Map,提供快速查找。
  • LinkedHashMap:类似于HashMap,但可以按照插入顺序遍历键值对。
  • TreeMap:基于红黑树实现的Map,可以按照自然顺序或自定义顺序排序键。

示例代码:HashMap的使用

import java.util.HashMap;public class HashMapExample {public static void main(String[] args) {HashMap<String, Integer> map = new HashMap<>();map.put("Apple", 1);map.put("Orange", 2);map.put("Banana", 3);System.out.println("Original Map: " + map);// Accessing values by keySystem.out.println("Value for 'Apple': " + map.get("Apple"));// Removing entriesmap.remove("Banana");System.out.println("Map after removal: " + map);}
}

示例代码:LinkedHashMap的使用

import java.util.LinkedHashMap;public class LinkedHashMapExample {public static void main(String[] args) {LinkedHashMap<String, Integer> map = new LinkedHashMap<>();map.put("Apple", 1);map.put("Orange", 2);map.put("Banana", 3);System.out.println("Original Map: " + map);// Iterating in insertion ordermap.forEach((key, value) -> System.out.println(key + " => " + value));}
}

示例代码:TreeMap的使用

import java.util.TreeMap;public class TreeMapExample {public static void main(String[] args) {TreeMap<String, Integer> map = new TreeMap<>();map.put("Banana", 3);map.put("Apple", 1);map.put("Orange", 2);System.out.println("Sorted Map: " + map);// TreeMap maintains natural ordering of keysmap.forEach((key, value) -> System.out.println(key + " => " + value));}
}

集合框架的高级特性

迭代器模式(Iterator)

迭代器模式是一种设计模式,它允许开发者在不知道集合底层实现的情况下,顺序访问集合中的元素。Java集合框架中的迭代器提供了hasNext()next()remove()等方法。

示例代码:使用迭代器遍历ArrayList
import java.util.ArrayList;
import java.util.Iterator;public class IteratorExample {public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("Java");list.add("Python");list.add("C++");Iterator<String> iterator = list.iterator();while (iterator.hasNext()) {String element = iterator.next();System.out.println(element);}}
}

集合操作

Java集合框架提供了一些集合操作方法,如addAll()retainAll()removeAll()clear()等,这些方法可以用于集合之间的操作。

示例代码:集合之间的操作
import java.util.ArrayList;
import java.util.List;public class CollectionOperationsExample {public static void main(String[] args) {List<String> list1 = new ArrayList<>();list1.add("Java");list1.add("Python");list1.add("C++");List<String> list2 = new ArrayList<>();list2.add("Python");list2.add("JavaScript");// Add all elements of list2 to list1list1.addAll(list2);System.out.println("After addAll: " + list1);// Remove all elements present in list2 from list1list1.removeAll(list2);System.out.println("After removeAll: " + list1);// Retain only elements present in list2list1.retainAll(list2);System.out.println("After retainAll: " + list1);// Clear the listlist1.clear();System.out.println("After clear: " + list1);}
}

集合的不可变性

不可变集合是指一旦创建,其内容就不能被修改的集合。Java提供了Collections.unmodifiableList()Collections.unmodifiableSet()Collections.unmodifiableMap()等方法来创建不可变集合。

示例代码:创建不可变集合
import java.util.Collections;
import java.util.List;
import java.util.ArrayList;public class UnmodifiableCollectionsExample {public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("Java");list.add("Python");list.add("C++");// Create an unmodifiable listList<String> unmodifiableList = Collections.unmodifiableList(list);// This will throw an UnsupportedOperationExceptiontry {unmodifiableList.add("Scala");} catch (UnsupportedOperationException e) {System.out.println("Cannot modify unmodifiable list");}// Accessing elements is allowedSystem.out.println("Element at index 1: " + unmodifiableList.get(1));}
}

序列化

Java集合框架中的一些实现支持序列化,这意味着集合可以被写入到文件或通过网络传输。要使集合可序列化,集合中的元素也必须是可序列化的。

示例代码:集合的序列化
import java.io.*;
import java.util.*;public class SerializationExample {public static void main(String[] args) throws IOException, ClassNotFoundException {ArrayList<String> list = new ArrayList<>();list.add("Java");list.add("Python");list.add("C++");// Write the list to a fileObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("list.ser"));out.writeObject(list);out.close();// Read the list from the fileObjectInputStream in = new ObjectInputStream(new FileInputStream("list.ser"));@SuppressWarnings("unchecked")ArrayList<String> deserializedList = (ArrayList<String>) in.readObject();in.close();System.out.println("Deserialized List: " + deserializedList);}
}

结语

Java集合框架不仅提供了基本的集合操作,还包含了丰富的高级特性,如迭代器模式、集合操作、不可变集合和序列化等。这些特性使得Java集合框架成为一个功能强大且灵活的工具,能够帮助开发者高效地处理数据集合。


整理不易,请点赞收藏关注

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

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

相关文章

Go 语言简介 -- 高效、简洁与现代化编程的完美结合

在现代软件开发领域&#xff0c;选择合适的编程语言对于项目的成功至关重要。Go 语言&#xff08;又称 Golang &#xff09;自 2009 年由Google发布以来&#xff0c;以其简洁的语法、高效的并发模型以及强大的性能&#xff0c;迅速成为开发者们的新宠。Go语言不仅融合了传统编译…

icloud照片怎么恢复到相册?2个方法,轻松解决烦恼

在现代生活中&#xff0c;照片承载着我们的回忆和珍贵的时刻&#xff0c;而iCloud提供了便捷的云存储服务&#xff0c;让用户可以方便地备份和同步手机上的照片、视频等文件。 然而&#xff0c;有时候我们可能会不小心删除了在iCloud上的照片&#xff0c;或者想要将iCloud照片…

青岛大学物理科学学院郭向欣教授

男&#xff0c;1973年1月生&#xff0c;山东济宁人。中国科学院百人计划杰出海外人才和上海市浦江人才&#xff0c;山东省泰山学者特聘教授&#xff0c;青岛市创业创新领军人才。固态离子学理事。博士&#xff0c;教授&#xff0c;博士生导师。 研究工作一直聚焦金属锂二次电池…

Golang:Sirupsen/logrus是一个日志库

Sirupsen/logrus是一个日志库 文档 https://github.com/Sirupsen/logrus 安装 go get github.com/sirupsen/logrus代码示例 package mainimport ("github.com/sirupsen/logrus" )func main() {var log logrus.New()log.Trace("Something very low level.&…

使用B2M 算法批量将可执行文件转为灰度图像

参考论文 基于二进制文件的 C 语言编译器特征提取及识别 本实验使用 B2M 算法将可执行文件转为灰度图像&#xff0c;可执行文件转为灰度图的流程如图 4-3 所示。将 可执行文件每 8 位读取为一个无符号的的整型常量&#xff0c;一个可执行文件得到一个一维向量&#xff0c; …

基于51单片机多功能太阳能充电器设计

1 绪论1.1 本课题研究背景及现状 当代社会随着一些不可再生资源如煤炭&#xff0c;石油等日益减少&#xff0c;使得各国社会经济越来越受能源问题的约制&#xff0c;因此许多国家开始逐渐的实行“阳光计划”&#xff0c;开发洁净的能源如太阳能&#xff0c;用以成为本国经济发…

ANOVA方差分析是什么?优思学院教你如何正确使用

ANOVA&#xff08;方差分析&#xff09;是一种统计方法&#xff0c;用来研究三个或三个以上样本平均数的差异是否显著。它可以帮助研究者判断不同组间的均值是否存在统计学上的显著差异。简单来说&#xff0c;如果我们想比较多个不同处理或条件对某个变量的影响&#xff0c;ANO…

【网络层】网络攻击 ARP 欺骗

文章目录 ARP 欺骗原理实战体验 ARP 欺骗原理 ARP&#xff08;地址解析协议&#xff09;欺骗是一种网络攻击技术&#xff0c;它利用了ARP协议的工作机制来欺骗网络中的主机。ARP协议用于将IP地址转换为物理MAC地址&#xff0c;以便在局域网内部进行数据包的传输。ARP欺骗的基本…

微信小程序毕业设计-跑腿系统项目开发实战(附源码+演示视频+LW)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;微信小程序毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计…

可监测的到手价范围

在品牌进行电商价格监测时&#xff0c;对优惠信息范围的关注至关重要。优惠促销的形式多样&#xff0c;会直接影响到消费者最终的到手价。因此&#xff0c;为了更准确地计算到手价&#xff0c;品牌需要确保监测的促销信息尽可能全面。 不同的电商平台&#xff0c;其优惠形式可…

C# 实现腾讯云点播之媒体管理常用接口

目录 关于腾讯云点播媒体管理 开发前准备 范例运行环境 常用媒体管理API 删除媒体 禁播媒体 获取媒体详细信息 查询媒体 小结 关于腾讯云点播媒体管理 腾讯云点播&#xff08;Video On Demand&#xff09;服务基于多年技术积累与基础设施建设&#xff0c;为有音视频应…

TypeScript-interface接口类型

interface接口类型 在TS中使用interface接口来描述对象数据的类型&#xff0c;常用于给对象的属性和方法添加类型约束 ⚠️ 一旦注解接口类型之后对象的属性和方法类型都需要满足要求&#xff0c;属性不能多也不能少 interface Person {name: stringage: number }const p: P…

揭秘APP广告变现的高效秘诀:如何让你的APP更赚钱?

在数字化时代&#xff0c;APP已成为人们获取信息、娱乐休闲的重要平台。对于许多内容创作者来说&#xff0c;如何通过APP实现盈利&#xff0c;是一个亟待解决的问题。而APP广告变现项目&#xff0c;正是其中一种备受关注的盈利模式。那么&#xff0c;如何有效地利用APP广告变现…

分数裂项方法及技巧

裂差 知识点 1 1 1 b − a a b 1 a − 1 b \frac{b-a}{ab} \frac{1}{a} - \frac{1}{b} abb−a​a1​−b1​ 证明&#xff1a; b − a a b b a b − a a b 1 a − 1 b \begin{align*} \\ &\frac{b-a}{ab} \\ &\frac{b}{ab} - \frac{a}{ab} \\ &\frac{1}{a}…

Flutter 中的 RawGestureDetector 小部件:全面指南

Flutter 中的 RawGestureDetector 小部件&#xff1a;全面指南 在Flutter中&#xff0c;处理用户手势是构建交互式应用的关键部分。RawGestureDetector是一个强大的小部件&#xff0c;它允许开发者识别和响应各种手势&#xff0c;包括但不限于点击、滑动、缩放等。本文将为您提…

web安全渗透测试十大常规项(二):web渗透测试之XSS跨站脚本攻击

渗透测试之XSS跨站脚本攻击 XSS跨站脚本攻击 XSS跨站脚本攻击

机器学习之快速森林分位数回归(Fast Forest Quantile Regression)

快速森林分位数回归(Fast Forest Quantile Regression)是一种用于回归任务的机器学习方法,旨在预测目标变量的特定分位数值。与传统回归模型不同,分位数回归能够提供目标变量的不同分布信息,而不仅仅是均值预测。这在需要估计不确定性范围或分布特征的应用中非常有用。 1…

python数据分析:爬取某东商城商品评论数据并做词云展示(含完整源码及详细注解)

python数据分析,爬取某东商城商品评论数据并做词云展示。 一、明确爬取的网页及结构 找到要爬取的网页地址,发现有一个获取json格式评论数据的接口: url = "https://club.jd.com/comment/productPageComments.action?callback=fetchJSON_comment98&productId=217…

基于图鸟UI的圈子商圈:一个全栈前端模板的探索与应用

摘要&#xff1a; 本文介绍了一个基于图鸟UI的纯前端模板——圈子商圈&#xff0c;它支持微信小程序、APP和H5等多平台开发。该模板不仅包含丰富的UI组件和页面模板&#xff0c;还提供了详尽的使用文档&#xff0c;旨在帮助开发者快速构建出酷炫且功能齐全的前端应用。本文将从…

MySQL 8窗口函数详解:高效数据处理的必备技能

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 MySQL 8窗口函数详解&#xff1a;高效数据处理的必备技能 前言窗口函数概述窗口函数的基本语法常用窗口函数类型窗口帧的定义与使用性能优化与注意事项 前言 你是否曾经遇到过需要对数据进行复杂统计…