2022年Java常用数据结构有哪些?极悦小编来告诉大家。
Java 编程语言在语言本身中提供了对数组的内置支持。它有一个特殊的语法来声明一个像int[]这样的数组,它是一个原始 int 类型的数组。您可以创建一个包含Java引用类型和基元的数组。
此外,与 C 编程语言不同,Java 中的数组是有界的,如果您使用无效索引 ,您将得到ArrayIndexOutOfBoundException 。
Java 中的数组也是同质的,你不能在一个数组中存储多种类型的对象——就像你只能在String[]中存储一个 String ,如果你试图存储 Integer,你将在运行时得到ArrayStoreException。
您可以进一步查看 数据结构和算法:使用 Java 深入研究 以了解有关数组和其他基本数据结构和算法的更多信息,更重要的是如何在 Java 程序中使用它们。
除了数组,链表是编程中的另一种基本数据结构。Java 提供了双向链表的实现java.util.LinkedList,只要需要链表数据结构就可以使用这个类。
由于 LinkedList 是 Collection 框架的一部分,它也实现了 Collection 和 Iterable 接口,这允许迭代它们。您可以查看本文以了解有关Java 中的 LinkedList 的更多信息。
而且,如果您正在修改 FAANG 面试的数据结构概念,那么我还建议您参加 Andrei Negaoi 在 Udemy 上开设的这个精彩的 FAANG 面试准备课程。它被称为掌握编程面试:大型科技 (FAANG) 面试,它将帮助您为 Facebook、Apple、Amazon、Netflix 和 Google 面试做准备。
哈希表、映射或字典是我见过的最通用的数据结构之一。我偶尔会用到 Map ,幸运的是,Java API 为不同的需求提供了几种 Map 数据结构的实现,如HashMap、Hashtable和ConcurrentHashMap。
它也被称为地图或字典数据结构,您可能听说过 Python 中的字典,它与 Java 中的地图相同。
映射为您提供 O(1) 功能,用于在您知道密钥的情况下取回值,这在大多数 Java 应用程序中是一个非常自然的用例。
Java API 还提供了一个作为java.util.Stack实现的 Stack 数据结构。此类扩展了用于存储元素的遗留 Vector 类。由于堆栈是后进先出(LIFO)数据结构,它提供了一个 push()方法来插入对象和一个 pop()方法从顶部消费元素。
栈在不同的编程任务中非常流行,比如计算表达式。对了,不要把 Stack 数据结构和stack memory搞混了,在 Java 中是用来存放局部变量和方法帧的。
队列数据结构在 Java 集合框架中也作为接口和一些具体实现(如ArrayBlockingQueue、LinkedList和PriorityQueue )提供。
尽管您也可以使用 LinkedList 或数组来实现 Queue,但最好使用经过试用和测试的现有类。
这不仅减少了开发时间,而且还提高了应用程序的整体代码质量和性能。BlockingQueue 是 Queue 接口的线程安全扩展,可用于在 Java 中实现生产者-消费者模式。
Set 是一种特殊的数据结构,不允许重复。这是一个很好的数据结构来存储唯一元素,例如 Id,例如 EmployeeId、OrderId、TradeId 等。每当您存储需要唯一的数据时,您都可以使用 Set 数据结构。如果您尝试插入重复项,Set 将不会接受它并且其方法将返回 false 以指示插入失败。
Java Collection API 提供了几个 Set 的实现,如 HashSet、TreeSet 和 LinkedHashSet,这对大多数情况来说已经足够了。这些集合,除了起始集合,还提供排序和插入顺序。
这个程序最好的一点是,您可以在手机上访问 50 个算法难题,以提高和提高您的算法技能,以及 100 多个大型科技公司经常提出的编码问题。更重要的是,您会得到关于您的解决方案是否正确的即时反馈。
这就是Java 开发人员最基本的一些数据结构。除了这些基本的数据结构,Java 集合框架中还有很多其他的数据结构,包括BlockingQueue和ConcurrentHashMap等并发数据结构。
你适合学Java吗?4大专业测评方法
代码逻辑 吸收能力 技术学习能力 综合素质
先测评确定适合在学习