Зарегистрируйтесь для доступа к 15+ бесплатным курсам по программированию с тренажером

Модуль 1. Урок 2. Интерфейс Collection. Java: Структуры данных

Видео может быть заблокировано из-за расширений браузера. В статье вы найдете решение этой проблемы.

Рассмотрели мы Iterable и переходим к Collection. Разница между этими двумя интерфейсами в том, что интерфейс Collection наследуется от Iterable, а другой не коллекция по своей сути.

Интерфейс Collection предоставляет самые базовые методы, которые должны присутствовать во всех коллекциях, которые работают с одномерной записью. Мы рассмотрим методы в общем интерфейсе Collection, а после будем рассматривать частности - Set, List, Queue.

Начнем с определения в официальном источнике.

“The root interface in the collection hierarchy. A collection represents a group of objects, known as its elements. Some collections allow duplicate elements and others do not. Some are ordered and others unordered. The JDK does not provide any direct implementations of this interface: it provides implementations of more specific subinterfaces like Set and List. This interface is typically used to pass collections around and manipulate them where maximum generality is desired.”

Самый базовый интерфейс в иерархии коллекций (в фреймворке Collection). Это группа объектов, которые называются элементами. Некоторые элементы позволяют хранить дубликаты, а некоторые нет.

API Collection. Огромное количество методов, смотрите по ссылке внизу и сразу начинайте использовать. Дальше будем рассматривать всевозможные методы из коллекций.

Выбираем самую простую имплементацию на базе Array.

import java.util.Collection;
public class ArrayCollection<T> implements Collection<T> {
}

Методы

`size()` - возвращает количество элементов коллекции
`isEmpty()` - если size равен нулю, то коллекция пуста
`contains()` - должен пройтись по всем элементам и узнать содержит ли коллекция нужный объект
`iterator()` - для итерации
`toArray()` - преобразование коллекции в массив
`add()` - добавление нового элемента
`remove()` - удаление элемента
`containsAll()` - true, если все элементы на входе содержатся в текущей коллекции
`addAll()` - добавление всех элементов входящей коллекции в текущую коллекцию
`removeAll()` - удаление всех элементов из текущей коллекции, которые содержатся во входящей коллекции.
`retainAll()` -  оставить одинаковые элементы в двух коллекциях
`clear()` - и ежу понятно

Все методы реализуем на практике! Вооооот..... :)

Полезные ссылки:

  • Документация по интерфейсу Collection

Source Code.

  • GitHub repo

Аватары экспертов Хекслета

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты

Об обучении на Хекслете

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно

  • 130 курсов, 2000+ часов теории
  • 1000 практических заданий в браузере
  • 360 000 студентов
Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff

Используйте Хекслет по-максимуму!

  • Задавайте вопросы по уроку
  • Проверяйте знания в квизах
  • Проходите практику прямо в браузере
  • Отслеживайте свой прогресс

Зарегистрируйтесь или войдите в свой аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»