- The Java Workshop
- David Cuartielles Andreas G?ransson Eric Foster Johnson
- 415字
- 2021-06-11 13:05:24
Introduction
Java comes with a built-in Collections API, allowing you to manipulate data structures with very little effort. A collection is an object that contains multiple elements. Collections are used to store, share, process, and communicate aggregated data. We call this system the Java collections framework.
As part of this framework, there are different components that are used to optimize our interaction with the actual data:
- Interfaces: Abstract data types that represent collections
- Implementations: Specific implementations of the collection interfaces
- Algorithms: Polymorphic methods used to process the data within a collection for operations such as sorting and searching
Note
Other programming languages have their own collection frameworks. For example, C++ has the Standard Template Library (STL). Java boasts simplicity when it comes to its collection framework.
Using the collections framework has many benefits, including a reduction in the complexity of creating programs that deal with data structures, an increase in the performance of programs, a simplification of API creation and use, and an increase in the reuse of functioning software.
The collections framework is relevant even when handling data that can be accessed by several processes simultaneously, as this would be the case in multithreaded programming scenarios. However, it is not the intention of this chapter to deal with concurrent programming.
The Collections API comes with five main interfaces:
- Set: A collection that contains no duplicates
- List: An ordered collection or sequence, allowing for duplicates
- Queue: A collection that sorts data in the order of its arrival, typically handled as a First In First Out (FIFO) process
- Deque: Essentially a queue that allows for data insertion at both ends, meaning that it can be handled both as FIFO and Last In First Out (LIFO)
- Map: Relates keys—which must be unique—to values
In this chapter, we will define the main interfaces (lists, sets, and maps), and explore examples of their respective uses. The framework has even more interfaces than the ones listed previously, but the others are either just variations of those listed or are outside the scope of this chapter. Furthermore, we will look at how arrays work in much more depth than we have previously.
The definition of a simple collection—in this case, a specific type of set would be as follows:
Set mySet = new HashSet();
Note
The different available classes for sets, lists, queues, deques, and maps are named after the interfaces. The different classes present different properties, as we will see later in the chapter.
- Getting Started with Gulp(Second Edition)
- 大學計算機基礎(第三版)
- 大學計算機應用基礎實踐教程
- Wireshark Network Security
- Mastering Python High Performance
- 名師講壇:Spring實戰開發(Redis+SpringDataJPA+SpringMVC+SpringSecurity)
- Getting Started with Gulp
- 領域驅動設計:軟件核心復雜性應對之道(修訂版)
- 微服務架構深度解析:原理、實踐與進階
- Xcode 6 Essentials
- 大數據時代的企業升級之道(全3冊)
- AMP:Building Accelerated Mobile Pages
- 30天學通C#項目案例開發
- DevOps 精要:業務視角
- 透視C#核心技術:系統架構及移動端開發