官术网_书友最值得收藏!

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.

主站蜘蛛池模板: 兰坪| 门源| 崇左市| 曲阳县| 伊金霍洛旗| 舞阳县| 扶余县| 苏州市| 临潭县| 高陵县| 孟村| 汝南县| 江源县| 巴里| 社旗县| 泽普县| 饶平县| 同德县| 屏南县| 威信县| 吉木萨尔县| 宁阳县| 西充县| 郧西县| 武功县| 吉木萨尔县| 阿拉尔市| 瑞金市| 丹东市| 区。| 台前县| 同心县| 谢通门县| 永嘉县| 江川县| 芜湖县| 湖南省| 长武县| 五峰| 扶沟县| 宁明县|