Java for Beginner
673 subscribers
541 photos
155 videos
12 files
827 links
Канал от новичков для новичков!
Изучайте Java вместе с нами!
Здесь мы обмениваемся опытом и постоянно изучаем что-то новое!

Наш YouTube канал - https://www.youtube.com/@Java_Beginner-Dev

Наш канал на RUTube - https://rutube.ru/channel/37896292/
Download Telegram
И не говори что не делал так 😊😂

https://t.me/Java_for_beginner_dev

#Mems
Please open Telegram to view this post
VIEW IN TELEGRAM
Более сложные сценарии использования Supplier

Supplier можно использовать для генерации данных, таких как случайные числа или уникальные идентификаторы.
import java.util.Random;
import java.util.function.Supplier;

public class DataGenerationExample {
public static void main(String[] args) {
// Создаем Supplier для генерации случайных чисел
Supplier<Integer> randomNumberSupplier = () -> new Random().nextInt(100);

// Генерируем и выводим 5 случайных чисел
for (int i = 0; i < 5; i++) {
System.out.println(randomNumberSupplier.get());
}
}
}
В этом примере мы используем Supplier для генерации случайных чисел. Метод get вызывается в цикле, и каждое новое число выводится на экран.


Пример использования Supplier в Stream API

Supplier можно использовать в Stream API для создания бесконечных потоков данных.
import java.util.stream.Stream;
import java.util.function.Supplier;

public class InfiniteStreamExample {
public static void main(String[] args) {
// Создаем Supplier для генерации случайных чисел
Supplier<Double> randomDoubleSupplier = () -> Math.random();

// Создаем бесконечный поток случайных чисел
Stream<Double> infiniteStream = Stream.generate(randomDoubleSupplier);

// Ограничиваем поток 5 элементами и выводим их
infiniteStream.limit(5).forEach(System.out::println);
}
}
В этом примере мы используем Supplier для создания бесконечного потока случайных чисел. Метод Stream.generate принимает Supplier и создает поток, который генерирует элементы с помощью метода get. Мы ограничиваем поток 5 элементами и выводим их на экран.


Пример использования Supplier для создания объектов с параметрами

Supplier можно использовать для создания объектов с параметрами, передавая их через замыкание.
import java.util.function.Supplier;

public class ParameterizedObjectCreationExample {
public static void main(String[] args) {
String name = "Alice";
int age = 30;

// Создаем Supplier для создания объекта Person с параметрами
Supplier<Person> personSupplier = () -> new Person(name, age);

// Создаем объект Person
Person person = personSupplier.get();
System.out.println(person); // Person{name='Alice', age=30}
}
}

class Person {
private String name;
private int age;

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

@Override
public String toString() {
return "Person{name='" + name + "', age=" + age + "}";
}
}
В этом примере мы используем Supplier для создания объекта Person с параметрами name и age. Параметры передаются через замыкание, и объект создается при вызове метода get.


#Java #Training #Medium #Functional_programming #Supplier #get
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Интерфейс Function<T, R> и метод apply

Function<T, R> — это функциональный интерфейс, представленный в Java 8 в пакете java.util.function. Он используется для преобразования объекта типа T в объект типа R. Интерфейс имеет один абстрактный метод apply(T t), который принимает объект типа T и возвращает объект типа R.

@FunctionalInterface
public interface Function<T, R> {
R apply(T t);
}


Как работает метод apply?

Метод apply — это основной метод интерфейса Function. Он принимает объект типа T и возвращает объект типа R. Этот метод часто используется для преобразования данных.

Пример:
Function<String, Integer> stringLength = str -> str.length();
System.out.println(stringLength.apply("Hello")); // 5
Здесь мы создали Function, который принимает строку и возвращает ее длину. Метод apply применяется к строке "Hello", и результат выводится на экран.


Плюсы и минусы использования Function

Плюсы:
Упрощает код, делая его более читаемым и выразительным.
Позволяет легко преобразовывать данные, особенно в сочетании с Stream API.
Поддерживает лямбда-выражения, что делает код более компактным.


Минусы:
Может быть избыточным для простых преобразований, где можно обойтись обычным методом.
Требует понимания функционального программирования для эффективного использования.


Пример использования Function для преобразования данных

Один из самых распространенных сценариев использования Function — это преобразование данных в Stream API.

import java.util.Arrays;
import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors;

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

// Создаем Function для преобразования строк в их длины
Function<String, Integer> nameLength = str -> str.length();

// Преобразуем список имен в список их длин
List<Integer> lengths = names.stream()
.map(nameLength)
.collect(Collectors.toList());

System.out.println(lengths); // [5, 3, 7, 5, 3]
}
}
В этом примере мы используем Function для преобразования списка имен в список их длин. Метод map в Stream API принимает Function и применяет его к каждому элементу потока.


#Java #Training #Medium #Functional_programming #Function #apply
Что выведет код?

public class Task310125 {
public static void main(String[] args) {
List<String> list = List.of("apple", "banana", "cherry");
list.set(1, "orange");
System.out.println(list);
}
}


#Tasks
"Это эмоции" , а вообще все в IT "friendly" 😂 😊

https://t.me/Java_for_beginner_dev

#Mems
Please open Telegram to view this post
VIEW IN TELEGRAM
Методы andThen, compose и их использование

Метод andThen

Метод andThen позволяет комбинировать две функции таким образом, что сначала выполняется первая функция, а затем вторая. Результат первой функции передается в качестве входного аргумента второй функции.

Пример:
Function<String, Integer> stringLength = str -> str.length();
Function<Integer, String> lengthDescription = length -> "Length is " + length;

// Комбинируем две функции
Function<String, String> describeLength = stringLength.andThen(lengthDescription);

System.out.println(describeLength.apply("Hello")); // Length is 5
В этом примере мы создали две функции: одна преобразует строку в ее длину, а другая преобразует длину в описание. Метод andThen объединяет их, и результат выполнения describeLength — это описание длины строки.


Метод compose

Метод compose позволяет комбинировать две функции таким образом, что сначала выполняется вторая функция, а затем первая. Результат второй функции передается в качестве входного аргумента первой функции.

Пример:
Function<Integer, String> intToString = num -> "Number is " + num;
Function<String, Integer> stringLength = str -> str.length();

// Комбинируем две функции
Function<String, String> describeLength = intToString.compose(stringLength);

System.out.println(describeLength.apply("Hello")); // Number is 5
В этом примере мы создали две функции: одна преобразует строку в ее длину, а другая преобразует число в строку с описанием. Метод compose объединяет их, и результат выполнения describeLength — это описание длины строки.


Пример использования Function в Stream API

Function часто используется в Stream API для преобразования данных.
import java.util.Arrays;
import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors;

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

// Создаем Function для преобразования имен в верхний регистр
Function<String, String> toUpperCase = str -> str.toUpperCase();

// Преобразуем список имен в список имен в верхнем регистре
List<String> upperCaseNames = names.stream()
.map(toUpperCase)
.collect(Collectors.toList());

System.out.println(upperCaseNames); // [ALICE, BOB, CHARLIE, DAVID, EVE]
}
}
В этом примере мы используем Function для преобразования списка имен в список имен в верхнем регистре. Метод map в Stream API принимает Function и применяет его к каждому элементу потока.


Пример использования Function с другими функциональными интерфейсами

Function можно комбинировать с другими функциональными интерфейсами, такими как Predicate, для создания более сложных сценариев.
import java.util.Arrays;
import java.util.List;
import java.util.function.Function;
import java.util.function.Predicate;
import java.util.stream.Collectors;

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

// Создаем Predicate для фильтрации имен, начинающихся на "A"
Predicate<String> startsWithA = name -> name.startsWith("A");

// Создаем Function для преобразования имен в их длины
Function<String, Integer> nameLength = str -> str.length();

// Фильтруем и преобразуем имена
List<Integer> lengths = names.stream()
.filter(startsWithA)
.map(nameLength)
.collect(Collectors.toList());

System.out.println(lengths); // [5]
}
}
В этом примере мы используем Predicate для фильтрации имен, начинающихся на "A", и Function для преобразования отфильтрованных имен в их длины.


#Java #Training #Medium #Functional_programming #Function #andThen #compose
Всем доброго субботнего утра! ☀️

Вот и начался последний месяц зимы! 🥶

Какие планы на выходные?
🏖️

А я ломаю голову что показать Вам завтра... Нужно что-то простое, но интересное и нужное в текущем стеке технологий...

Соберу сейчас варианты и ниже организую голосование 😎 для выбора.

Предлагайте! ☝️

Всем хороших выходных! 🤟
Please open Telegram to view this post
VIEW IN TELEGRAM
Всем привет! 🖐

Сегодня как всегда в 16:00 по МСК, я жду вас на встречу, где мы начнем писать сервис доставки товаров с привязкой к Яндекс Картам. 😏

Ничего необычного, но пройдемся по стандартам создания Rest-приложений, продумаем логику бэкенда да и что-то напишем 🫣

Рекомендуется всем кто хочет набить руку в написании бэка для web-приложений!
🫵

И раз предложений ни от кого не поступило я придумал тему сам 😜

Жду всех, как всегда 🤨🫡
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
Методы по умолчанию в интерфейсах (default методы)

Методы по умолчанию — это методы в интерфейсах, которые имеют реализацию по умолчанию. Они были добавлены в Java 8, чтобы позволить разработчикам добавлять новые методы в интерфейсы, не нарушая существующие реализации этих интерфейсов.

До Java 8 интерфейсы могли содержать только абстрактные методы (без реализации). Это создавало проблемы при необходимости добавить новый метод в интерфейс, так как все классы, реализующие этот интерфейс, должны были бы предоставить реализацию нового метода. Методы по умолчанию решают эту проблему.


Пример:
interface Vehicle {
void start(); // Абстрактный метод

default void stop() { // Метод по умолчанию
System.out.println("Vehicle stopped");
}
}

class Car implements Vehicle {
@Override
public void start() {
System.out.println("Car started");
}
}

public class Main {
public static void main(String[] args) {
Car car = new Car();
car.start(); // Вызов абстрактного метода
car.stop(); // Вызов метода по умолчанию
}
}
В этом примере метод stop() имеет реализацию по умолчанию, и класс Car не обязан его переопределять.


Зачем они были добавлены в Java 8?

Методы по умолчанию были добавлены для поддержки эволюции API. Например, в Java 8 была добавлена поддержка лямбда-выражений, и для этого потребовалось добавить новые методы в интерфейсы коллекций, такие как forEach, stream и другие. Если бы эти методы были абстрактными, все существующие классы, реализующие эти интерфейсы, сломались бы. Методы по умолчанию позволили добавить новые методы без нарушения обратной совместимости.

Пример:
interface List<E> {
void add(E element); // Абстрактный метод

default void forEach(Consumer<? super E> action) { // Метод по умолчанию
for (E element : this) {
action.accept(element);
}
}
}
Теперь все классы, реализующие List, могут использовать метод forEach без необходимости его переопределения.


Конфликты при множественном наследовании интерфейсов и их разрешение

Если класс реализует два интерфейса, и оба интерфейса имеют метод по умолчанию с одинаковой сигнатурой, возникает конфликт. В этом случае компилятор требует, чтобы класс явно переопределил этот метод.

Пример:
interface A {
default void show() {
System.out.println("Interface A");
}
}

interface B {
default void show() {
System.out.println("Interface B");
}
}

class C implements A, B {
@Override
public void show() {
System.out.println("Class C");
}
}

public class Main {
public static void main(String[] args) {
C c = new C();
c.show(); // Вывод: Class C
}
}
В этом примере класс C должен переопределить метод show(), чтобы разрешить конфликт между интерфейсами A и B.


Плюсы и минусы методов по умолчанию

Плюсы:
Гибкость API: Позволяют добавлять новые методы в интерфейсы без нарушения существующих реализаций.
Обратная совместимость: Упрощают эволюцию библиотек и фреймворков.
Повторное использование кода: Реализация по умолчанию может быть использована в нескольких классах.


Минусы:
Сложность отладки: Если метод по умолчанию используется в нескольких интерфейсах, может быть сложно отследить, какая реализация используется.
Конфликты при множественном наследовании: Требуют явного переопределения в случае конфликтов.


#Java #Training #Medium #Functional_programming #Interface #default
Что выведет код?

public class Task030225 {
public static void main(String[] args) {
StringBuilder sb = new StringBuilder("hello");
sb.append(" world").reverse().delete(0, 6).reverse();
System.out.println(sb);
}
}


#Tasks
Варианты ответа:
Anonymous Quiz
9%
olleh
14%
world
25%
dlrow olleh
52%
hello