en
Feedback
Java | Вопросы собесов

Java | Вопросы собесов

Open in Telegram

📈 Analytical overview of Telegram channel Java | Вопросы собесов

Channel Java | Вопросы собесов (@easy_java_ru) in the Russian language segment is an active participant. Currently, the community unites 11 456 subscribers, ranking 10 894 in the Technologies & Applications category and 57 468 in the Russia region.

📊 Audience metrics and dynamics

Since its creation on невідомо, the project has demonstrated rapid growth, gathering an audience of 11 456 subscribers.

According to the latest data from 10 June, 2026, the channel demonstrates stable activity. Although there has been a change in the number of participants by 10 over the last 30 days and by 2 over the last 24 hours, overall reach remains high.

  • Verification status: Not verified
  • Engagement rate (ER): The average audience engagement rate is 10.71%. Within the first 24 hours after publication, content typically collects 7.28% reactions from the total number of subscribers.
  • Post reach: On average, each post receives 1 227 views. Within the first day, a publication typically gains 834 views.
  • Reactions and interaction: The audience actively supports content: the average number of reactions per post is 6.
  • Thematic interests: Content is focused on key topics such as ставь, void, string, строка, static.

📝 Description and content policy

The author describes the resource as a platform for expressing subjective opinions:
Cайт easyoffer.ru Реклама @easyoffer_adv ВП @easyoffer_vp Тесты t.me/+icUwivvbGOkwNWRi Задачи t.me/+8eqUTboisnkyZjQy Вакансии t.me/+4pspF5nDjgM4MjQy

Thanks to the high frequency of updates (latest data received on 11 June, 2026), the channel maintains relevance and a high level of publication reach. Analytics show that the audience actively interacts with content, making it an important point of influence in the Technologies & Applications category.

11 456
Subscribers
+224 hours
+77 days
+1030 days
Posts Archive
🤔 Какие могут проблемы при реализации Hashcode? Реализация метода hashCode в Java может привести к нескольким проблемам, если она сделана неправильно. Эти проблемы могут привести к некорректной работе хэш-структур данных, таких как HashMap, HashSet и другие. Рассмотрим основные проблемы, которые могут возникнуть при неправильной реализации метода hashCode. 🚩Основные проблемы 🟠Нарушение контракта между `equals` и `hashCode` Если два объекта равны согласно методу equals, они должны иметь одинаковый хэш-код. Нарушение этого правила приведет к тому, что объекты, которые равны с точки зрения equals, могут оказаться в разных корзинах хэш-таблицы. Убедитесь, что если equals возвращает true для двух объектов, то их хэш-коды одинаковы.
@Override
public boolean equals(Object obj) {
    // Реализация метода equals
}

@Override
public int hashCode() {
    // Реализация метода hashCode
}     
🟠Изменяемые объекты в качестве ключей Если объект, который используется в качестве ключа в HashMap, изменяется таким образом, что изменяется его хэш-код, это может привести к тому, что объект станет недоступным. Избегайте использования изменяемых объектов в качестве ключей в хэш-таблицах или обеспечьте, чтобы поля, влияющие на хэш-код, не изменялись после создания объекта.
// Плохой пример
Map<Person, String> map = new HashMap<>();
Person person = new Person("Alice");
map.put(person, "Engineer");
person.setName("Bob"); // Изменение, влияющее на hashCode
String profession = map.get(person); // Может вернуть null     
🟠Неравные объекты с одинаковым хэш-кодом Два неравных объекта могут иметь одинаковый хэш-код, что приведет к увеличению числа коллизий. Это может снизить производительность хэш-таблицы. Хотя это невозможно полностью избежать, хорошая реализация hashCode должна стараться минимизировать количество таких коллизий.
@Override
public int hashCode() {
    int result = 17;
    result = 31 * result + (name != null ? name.hashCode() : 0);
    result = 31 * result + age;
    return result;
}     
🟠Производительность метода `hashCode` Если метод hashCode реализован неэффективно, это может привести к снижению производительности всей программы. Убедитесь, что метод hashCode выполняется быстро и эффективно, особенно для часто используемых объектов. 🟠Сложные вычисления хэш-кода Слишком сложные вычисления в методе hashCode могут негативно сказаться на производительности. Используйте простые и эффективные алгоритмы для вычисления хэш-кода.
@Override
public int hashCode() {
    return Objects.hash(name, age);
}
     
Пример правильной реализации equals и hashCode
import java.util.Objects;

public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;
        if (obj == null || getClass() != obj.getClass()) return false;
        Person person = (Person) obj;
        return age == person.age && Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Что такое volatile? Это ключевое слово в Java, используемое для обозначения переменной, значение которой может изменяться несколькими потоками. Оно гарантирует, что все потоки будут видеть актуальное значение переменной, избегая кеширования в потоках. Однако volatile не обеспечивает атомарность операций. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что такое heap, stack? В контексте Java, Heap (куча) и Stack (стек) являются областями памяти, используемыми JVM для управления памятью, необходимой для выполнения программы. Каждая из этих областей имеет свои характеристики и используется для разных целей. 🚩Heap (Куча) Heap — это область памяти, выделенная для динамического распределения памяти объектов и массивов. Все объекты, созданные с использованием оператора new, размещаются в куче. 🟠Особенности Куча разделена на поколения: молодое поколение (Young Generation) и старое поколение (Old Generation). Молодое поколение включает в себя области Eden Space и Survivor Spaces (S0 и S1). Старое поколение хранит долгоживущие объекты. 🟠Управление памятью Куча управляется сборщиком мусора (Garbage Collector), который автоматически освобождает память, занятую объектами, которые больше не используются. 🟠Использование Куча используется для хранения объектов, массивов и классов, информация о которых сохраняется на протяжении всего времени их жизни.
public class Example {
    public static void main(String[] args) {
        Example obj = new Example(); // obj создается в куче
    }
}
🚩Stack (Стек) Стек — это область памяти, используемая для управления вызовами методов и хранения локальных переменных, параметров методов и информации о возвратах. 🟠Особенности Каждый поток имеет свой собственный стек. Стек хранит кадры (frames) для каждого вызова метода. Каждый кадр содержит локальные переменные метода и информацию о вызовах. 🟠Управление памятью Память в стеке автоматически управляется при вызове методов и выходе из них. Когда метод вызывается, создается новый кадр в стеке; когда метод завершает выполнение, его кадр удаляется из стека. 🟠Использование Стек используется для хранения примитивных типов данных и ссылок на объекты, которые находятся в куче. Локальные переменные методов и параметры методов хранятся в стеке.
public class Example {
    public static void main(String[] args) {
        int localVar = 10; // localVar хранится в стеке
        Example obj = new Example(); // Ссылка на obj хранится в стеке, а сам объект — в куче
        obj.method();
    }

    public void method() {
        int anotherVar = 20; // anotherVar хранится в стеке
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Какую структуру данных реализует LinkedList? Реализует связанную структуру данных — двусвязный список. Каждый узел содержит данные и ссылки на предыдущий и следующий элементы, что делает добавление и удаление эффективным, но доступ к элементам — медленным (линейный поиск). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что такое модификатор default equals и hashcode? Модификаторы доступа в Java определяют уровень доступа к классам, методам и переменным. Однако, если говорить о equals и hashCode в контексте модификаторов, то мы имеем в виду их реализацию по умолчанию, предоставляемую классом java.lang.Object. 🚩Реализация 🟠Метод `equals` по умолчанию Метод equals в классе Object по умолчанию проверяет, являются ли два объекта одним и тем же экземпляром. Это проверка на ссылочное равенство.
public boolean equals(Object obj) {
    return (this == obj);
}
🟠Метод `hashCode` по умолчанию Метод hashCode в классе Object по умолчанию возвращает уникальный целочисленный идентификатор для каждого объекта. Этот идентификатор обычно представляет собой адрес объекта в памяти.
public native int hashCode();
🚩Когда нужно переопределять Переопределение методов equals и hashCode необходимо, когда вы хотите, чтобы два различных объекта были равны, если их состояния равны, а не если они являются одним и тем же объектом.
public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) return true;
        if (obj == null || getClass() != obj.getClass()) return false;
        Person person = (Person) obj;
        return age == person.age && Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    public static void main(String[] args) {
        Person p1 = new Person("Alice", 25);
        Person p2 = new Person("Alice", 25);

        System.out.println(p1.equals(p2)); // true
        System.out.println(p1.hashCode() == p2.hashCode()); // true
    }
}
Ставь 👍 и забирай 📚 Базу знаний

🤔 Массив — статическая структура данных или динамическая? Является статической структурой данных, так как его размер задаётся при создании и не может изменяться. Однако содержимое массива можно изменять, а для работы с динамическими структурами лучше использовать коллекции, такие как ArrayList. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Когда stream начинает свое выполнение? В Java Streams API потоки данных (Stream) начинают своё выполнение только при вызове терминального операции. Это ключевая особенность, которая отличает ленивые (lazy) промежуточные операции от жадных (eager) терминальных операций. 🚩Промежуточные и терминальные операции 🟠Промежуточные операции (Intermediate Operations) Промежуточные операции возвращают новый поток и не инициируют выполнение. Они являются ленивыми, то есть, они откладывают выполнение до тех пор, пока не будет вызвана терминальная операция. Примеры: filter, map, sorted, distinct, flatMap, и т.д. Промежуточные операции составляют цепочку, которая настраивает конвейер обработки данных.
Stream<String> stream = Stream.of("one", "two", "three")
    .filter(s -> s.length() > 3)
    .map(String::toUpperCase);   
🟠Терминальные операции (Terminal Operations) Терминальные операции запускают выполнение всего конвейера потоков. Они потребляют поток и возвращают либо результат, либо выполняют побочные действия. Примеры: forEach, collect, reduce, count, findFirst, findAny, allMatch, noneMatch, и т.д.
long count = stream.count(); // Запуск выполнения   
🚩Пример Рассмотрим пример, где промежуточные операции filter и map не инициируют выполнение, а только настройку конвейера. Выполнение начинается только при вызове терминальной операции forEach.
import java.util.Arrays;
import java.util.List;
import java.util.stream.Stream;

public class StreamExample {
    public static void main(String[] args) {
        List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "David");

        // Настройка конвейера операций
        Stream<String> nameStream = names.stream()
            .filter(name -> {
                System.out.println("Filter: " + name);
                return name.length() > 3;
            })
            .map(name -> {
                System.out.println("Map: " + name);
                return name.toUpperCase();
            });

        System.out.println("Before terminal operation");

        // Терминальная операция, которая запускает выполнение
        nameStream.forEach(name -> System.out.println("Final result: " + name));

        System.out.println("After terminal operation");
    }
}
🚩Ожидаемый вывод Вывод на экран покажет, что промежуточные операции выполняются только при вызове терминальной операции.
Before terminal operation
Filter: Alice
Map: Alice
Final result: ALICE
Filter: Bob
Filter: Charlie
Map: Charlie
Final result: CHARLIE
Filter: David
Map: David
Final result: DAVID
After terminal operation
Ставь 👍 и забирай 📚 Базу знаний

Почему Java - лучший язык для программирования в 2025 году? Если вы до сих пор выбираете новое направление в IT.. скорее посе
Почему Java - лучший язык для программирования в 2025 году? Если вы до сих пор выбираете новое направление в IT.. скорее посетите канал Павла Сорокина! Вся выжимка за 5 лет работы Java-разработчиком от ведущего специалиста! 🧑‍💻Выбирайте уровень подготовки и смотрите возможные решения: — Начало положено: Только начали изучать язык, у вас все только впереди! — Улучшение знаний: Высокий доход требует должных знаний - научитесь! — Хочется зарабатывать: Узнаете, как пройти собеседование на топ-работу с первого раза!

🤔 Является ли коллекция HashMap потоко безопасной? Нет, не является потоко безопасной. При одновременном доступе нескольких потоков возможны повреждения данных или ошибки. Для многопоточной работы используют ConcurrentHashMap или синхронизацию через Collections.synchronizedMap(). Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

🤔 Что знаешь про модели памяти в Java? Модель памяти Java (Java Memory Model, JMM) определяет, как взаимодействуют потоки через память и как изменения, сделанные одним потоком, становятся видимыми для других потоков. Модель памяти Java является фундаментальной частью многопоточной среды в Java, обеспечивающей корректность и предсказуемость поведения многопоточных программ. 🚩Основные аспекты 🟠Взаимодействие потоков и памяти: JMM определяет, как потоки взаимодействуют с переменными (данными), хранящимися в общей памяти. Каждая переменная в Java хранится в основной памяти (main memory), и потоки могут иметь локальные копии этих переменных в своих рабочих кешах. 🟠Чтение и запись переменных Когда поток читает переменную, он может читать ее из своей локальной копии или из основной памяти. Когда поток записывает переменную, он может записывать ее в свою локальную копию или непосредственно в основную память. 🚩Гарантии JMM 🟠Последовательная согласованность (Sequential Consistency) Последовательная согласованность гарантирует, что действия всех потоков будут выполняться в том порядке, в котором они были написаны в коде, если нет явных указаний на обратное. 🟠Видимость (Visibility) Видимость означает, что изменения, сделанные одним потоком, становятся видимыми для других потоков. В JMM видимость изменений обеспечивается с помощью синхронизации. 🟠Произвольный порядок выполнения (Out-of-Order Execution) JMM допускает оптимизации, такие как переупорядочивание инструкций, чтобы улучшить производительность, но гарантирует, что видимость и порядок выполнения будут сохраняться, как описано в спецификации.
public class VisibilityExample {
    private static boolean flag = false;
    private static int counter = 0;

    public static void main(String[] args) throws InterruptedException {
        Thread writer = new Thread(() -> {
            counter = 42;
            flag = true;
        });

        Thread reader = new Thread(() -> {
            while (!flag) {
                // Ждем пока флаг не станет true
            }
            System.out.println("Counter: " + counter);
        });

        writer.start();
        reader.start();

        writer.join();
        reader.join();
    }
}
Ставь 👍 и забирай 📚 Базу знаний

Догфудинг, выстрел в ногу и пять бинарей: путь от виртуалки к облаку MWS В новом выпуске подкаста «Расскажите про MWS» обсужд
Догфудинг, выстрел в ногу и пять бинарей: путь от виртуалки к облаку MWS В новом выпуске подкаста «Расскажите про MWS» обсуждаем как развивались потребности команд МТС от простой виртуалки по запросу к полноценному облаку. Андрей Дикий — CTO Container Ecosystem MWS рассказывает: 🔴 Зачем отправлять разработчиков дежурить на третью линию поддержки 🔴 Какой склад ума нужен для разработки контейнерной экосистемы облака 🔴 Какие технические головоломки приходится решать команде Смотрите и слушайте на всех популярных площадках: 🎬 YouTube 🎬 VK Видео 🎧 Яндекс Музыка 🎧 Apple Podcasts 🎧 Mave Digital

🤔 Какой метод класса String используется для получения подстроки?
Anonymous voting

Помощь в трудоустройстве в IT-сфере! В России из-за дефицита айтишников запустили бесплатную программу по обучению IT-специал
+9
Помощь в трудоустройстве в IT-сфере! В России из-за дефицита айтишников запустили бесплатную программу по обучению IT-специалистов. Теперь любой желающий может попробовать себя в IT с полного нуля и начать обучение бесплатно! Узнайте про дальнейшее трудоустройство в ведущие IT-компании для восполнения кадрового дефицита. Для этого нужно: - Перейти по ссылке - Заполнить анкету и ответить на вопросы (занимает менее 3 минут) - На основании ваших ответов вы сразу узнаете, подходит ли вам сфера IT и сможете ли вы в ней работать Перейти на сайт #реклама 16+ urban-university.ru О рекламодателе

📌 Почему hashcode могут быть равны? 💬 Спрашивают в 6% собеседований Хеш-коды могут быть равны для разных объектов из-за того, что они являются конечными представлениями данных, а количество возможных хеш-кодов ограничено. В Java метод hashCode возвращает значение типа int, что означает, что существует только \(2^{32}\) возможных значений хеш-кодов. Однако количество возможных объектов значительно больше, чем \(2^{32}\), что приводит к коллизиям хеш-кодов. 🤔 Основные причины равенства хеш-кодов: 1️⃣ Ограниченный диапазон хеш-кодов: ➕ Хеш-коды представлены 32-битным целым числом, что дает \(2^{32}\) возможных значений. Это означает, что множество объектов должно быть отображено в это ограниченное пространство хеш-кодов, что приводит к коллизиям. 2️⃣ Коллизии хеш-кодов: ➕ Коллизия возникает, когда два разных объекта имеют одинаковый хеш-код. Это неизбежно при использовании конечного диапазона хеш-кодов для представления множества объектов. 🤔 Как работают коллизии хеш-кодов в Java В Java структуры данных, такие как HashMap и HashSet, обрабатывают коллизии хеш-кодов, используя внутренние механизмы для разрешения коллизий. При коллизии хеш-кодов, когда два разных объекта имеют одинаковый хеш-код, они все равно могут быть правильно размещены и найдены в хеш-таблице. 🤔 Пример: Рассмотрим два объекта, которые имеют одинаковый хеш-код, но не равны с точки зрения метода equals.
public class Example {
    private int value;

    public Example(int value) {
        this.value = value;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (obj == null || getClass() != obj.getClass()) {
            return false;
        }
        Example example = (Example) obj;
        return value == example.value;
    }

    @Override
    public int hashCode() {
        return value % 10; // Искусственно создаем коллизии для демонстрации
    }

    public static void main(String[] args) {
        Example ex1 = new Example(1);
        Example ex2 = new Example(11);

        System.out.println(ex1.hashCode()); // 1
        System.out.println(ex2.hashCode()); // 1

        System.out.println(ex1.equals(ex2)); // false

        HashSet<Example> set = new HashSet<>();
        set.add(ex1);
        set.add(ex2);

        System.out.println(set.size()); // 2, так как объекты разные
    }
}
🤔 Обработка коллизий в хеш-таблицах В HashMap и HashSet используются различные методы для разрешения коллизий: 1️⃣ Цепочки (Chaining): ➕ Каждый элемент в хеш-таблице указывает на список (или другую структуру), содержащий все элементы с одинаковым хеш-кодом. 2️⃣ Открытая адресация (Open Addressing): ➕ В случае коллизии алгоритм ищет другую позицию в хеш-таблице для размещения элемента, используя определенную стратегию пробирования (linear probing, quadratic probing и т.д.). 🤔 Краткое объяснение Хеш-коды могут быть равны для разных объектов, потому что диапазон возможных хеш-кодов ограничен \(2^{32}\) значениями, что приводит к коллизиям. Структуры данных в Java, такие как HashMap и HashSet, имеют механизмы для разрешения этих коллизий и обеспечения корректной работы. 🔥 ТОП ВОПРОСОВ С СОБЕСОВ 🔒 База собесов | 🔒 База тестовых

🤔 В чем идея многопоточности? Многопоточность позволяет выполнять несколько задач одновременно в рамках одного процесса. Это улучшает производительность и эффективность, особенно на многопроцессорных системах. Однако требует контроля синхронизации для предотвращения гонок данных и других проблем. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

Универсальная платформа обработки и хранения данных YDB Узнайте больше про возможности и интерфейс на сайте СУБД Яндекса. Узнать больше #реклама 16+ ydb.yandex.ru О рекламодателе Реклама на Яндексе

🤔 Откуда берутся методы equals и hashcode? Методы equals и hashCode являются методами класса java.lang.Object в Java. Все классы в Java, неявно или явно, наследуются от класса Object, поэтому они унаследуют эти методы. 🚩Класс `java.lang.Object` Класс Object является корневым классом в иерархии классов Java. Каждый класс в Java наследуется от этого класса, либо прямо, либо через цепочку других классов. 🚩Метод `equals` Метод equals используется для сравнения объектов на равенство. Метод equals должен следовать следующим правилам: Симметричность: Для любых ненулевых значений x и y, x.equals(y) должно возвращать true, если и только если y.equals(x) возвращает true. Транзитивность: Для любых ненулевых значений x, y и z, если x.equals(y) возвращает true и y.equals(z) возвращает true, то x.equals(z) должно возвращать true. Согласованность: Для любых ненулевых значений x и y, повторные вызовы x.equals(y) должны возвращать одно и то же значение, пока объекты остаются неизменными. Сравнение с null: Для любого ненулевого значения x, x.equals(null) должно возвращать false. 🚩Метод `hashCode` Метод hashCode возвращает хеш-код объекта, который используется для повышения производительности в структурах данных, таких как HashMap, HashSet и Hashtable. Подразумеваемый контракт: Метод hashCode должен следовать следующим правилам: Согласованность: Если объект не изменяется, повторные вызовы метода hashCode должны возвращать одно и то же значение. Согласованность с equals: Если два объекта равны согласно методу equals, их хеш-коды также должны быть равны. Неравенство: Если два объекта не равны согласно методу equals, их хеш-коды не обязательно должны быть различными, но желательно минимизировать количество таких коллизий. 🚩Переопределение методов `equals` и `hashCode` Чтобы обеспечить правильное поведение этих методов в пользовательских классах, их часто переопределяют.
public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (obj == null || getClass() != obj.getClass()) {
            return false;
        }
        Person person = (Person) obj;
        return age == person.age && Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    public static void main(String[] args) {
        Person person1 = new Person("Alice", 25);
        Person person2 = new Person("Alice", 25);

        System.out.println(person1.equals(person2)); // true
        System.out.println(person1.hashCode() == person2.hashCode()); // true
    }
}
🚩Генерация методов `equals` и `hashCode` в IDE Современные IDE, такие как IntelliJ IDEA и Eclipse, могут автоматически генерировать методы equals и hashCode на основе полей класса. Это помогает избежать ошибок и обеспечить правильное соблюдение контрактов. Ставь 👍 и забирай 📚 Базу знаний

🤔 Char — символьный или числовой тип данных? char в Java — это символьный тип данных, который используется для представления одиночных символов Unicode. При этом он хранится как 16-битное числовое значение, соответствующее коду символа в таблице Unicode. Это позволяет выполнять над символами арифметические операции, такие как инкремент или сравнение. Но основной его смысл — хранение символов. Ставь 👍 если знал ответ, 🔥 если нет Забирай 📚 Базу знаний

Помощь в трудоустройстве в IT-сфере! По всей России объявили бесплатную программу на шестимесячное обучение по IT-cпециальнос
+9
Помощь в трудоустройстве в IT-сфере! По всей России объявили бесплатную программу на шестимесячное обучение по IT-cпециальностям. Запись на участие в программе продлится до конца июля, но чтобы туда попасть, нужно пройти специальный профтест. По результату тестирования сразу узнаете, какая профессия вам подойдет, и проходите ли вы на бесплатное обучение. Перейти на сайт #реклама 16+ urban-university.ru О рекламодателе

🤔 Сколько функциональностей можно поместить в одно Lambda-выражение? В одном лямбда-выражении можно определить и реализовать только одну функциональность, поскольку лямбда-выражение предназначено для реализации одного абстрактного метода функционального интерфейса. Функциональный интерфейс — это интерфейс, который содержит только один абстрактный метод. 🚩Пример 🟠Использование `Consumer` Consumer — это функциональный интерфейс, который принимает один аргумент и не возвращает результата.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");

// Лямбда-выражение для Consumer
names.forEach(name -> System.out.println(name));
🟠Использование `Function` Function — это функциональный интерфейс, который принимает один аргумент и возвращает результат.
Function<String, Integer> lengthFunction = str -> str.length();
int length = lengthFunction.apply("Hello");
System.out.println("Length: " + length); // Вывод: Length: 5
🟠Использование `Predicate` Predicate — это функциональный интерфейс, который принимает один аргумент и возвращает логическое значение.
Predicate<String> startsWithA = str -> str.startsWith("A");
boolean result = startsWithA.test("Alice");
System.out.println("Starts with A: " + result); // Вывод: Starts with A: true
🚩Сложные лямбда-выражения Хотя одно лямбда-выражение предназначено для реализации одной функциональности, вы можете включить в него более сложную логику, используя блоки кода {}.
Predicate<String> complexPredicate = str -> {
    if (str == null || str.isEmpty()) {
        return false;
    }
    return str.startsWith("A") && str.length() > 3;
};

boolean result = complexPredicate.test("Alice");
System.out.println("Complex Predicate: " + result); // Вывод: Complex Predicate: true
🚩Сочетание нескольких лямбда-выражений Если нужно выполнить несколько различных функциональностей, можно комбинировать несколько лямбда-выражений или цепочку вызовов.
List<String> names = Arrays.asList("Alice", "Bob", "Charlie", "Alex");

// Фильтрация, преобразование и итерация
names.stream()
    .filter(name -> name.startsWith("A")) // Predicate
    .map(name -> name.toUpperCase()) // Function
    .forEach(name -> System.out.println(name)); // Consumer
🚩Вложенные лямбда-выражения В некоторых случаях вы можете встретить вложенные лямбда-выражения, особенно при работе с функциями высшего порядка.
BiFunction<Integer, Integer, Integer> add = (a, b) -> a + b;
Function<Integer, Function<Integer, Integer>> addPartial = a -> b -> add.apply(a, b);

Function<Integer, Integer> add5 = addPartial.apply(5);
int result = add5.apply(3); // 5 + 3 = 8
System.out.println("Result: " + result); // Вывод: Result: 8
Ставь 👍 и забирай 📚 Базу знаний