⚙️ Lombok @SuperBuilder
@SuperBuilder из библиотеки Lombok облегчает процесс создания объектов, используя паттерн "Builder", и поддерживает наследование. Это позволяет избежать написания излишнего кода при создании сложных иерархий классов.
🔗 Документация
👩💻
@javaquiz
@SuperBuilder из библиотеки Lombok облегчает процесс создания объектов, используя паттерн "Builder", и поддерживает наследование. Это позволяет избежать написания излишнего кода при создании сложных иерархий классов.
🔗 Документация
👩💻
@javaquiz
⚙️ Метод String.stripIndent() убирает общие начальные пробелы из всех строк многострочного текста, что делает его более удобным для чтения и форматирования. Это особенно полезно при работе с текстовыми блоками в коде.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/String.html#stripIndent())
👩💻
@javaquiz
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/String.html#stripIndent())
👩💻
@javaquiz
⚙️ CompletableFuture.delayedExecutor()
CompletableFuture.delayedExecutor() дает возможность запустить задачу с задержкой, не блокируя основной поток. Это полезный инструмент для асинхронных операций с задержкой.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/concurrent/CompletableFuture.html#delayedExecutor(long,java.util.concurrent.TimeUnit))
👩💻
@javaquiz
CompletableFuture.delayedExecutor() дает возможность запустить задачу с задержкой, не блокируя основной поток. Это полезный инструмент для асинхронных операций с задержкой.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/concurrent/CompletableFuture.html#delayedExecutor(long,java.util.concurrent.TimeUnit))
👩💻
@javaquiz
⚙️ CompletableFuture.delayedExecutor()
CompletableFuture.delayedExecutor() дает возможность выполнить задачу с задержкой без блокировки основного потока. Это полезный инструмент для асинхронных операций с задержкой.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/concurrent/CompletableFuture.html#delayedExecutor(long,java.util.concurrent.TimeUnit))
👩💻
@javaquiz
CompletableFuture.delayedExecutor() дает возможность выполнить задачу с задержкой без блокировки основного потока. Это полезный инструмент для асинхронных операций с задержкой.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/concurrent/CompletableFuture.html#delayedExecutor(long,java.util.concurrent.TimeUnit))
👩💻
@javaquiz
⚙️ Метод Optional.orElseThrow() используется для генерации исключения в случае, если Optional является пустым. В отличие от orElse(), он не требует указания значения по умолчанию, а в отличие от orElseGet() не создает лишние объекты.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/Optional.html#orElseThrow())
👩💻
@javaquiz
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/Optional.html#orElseThrow())
👩💻
@javaquiz
⚙️ MemorySegment.allocateNative()
MemorySegment.allocateNative() из Java Foreign Function & Memory API (FFM API, начиная с Java 19) предоставляет возможность безопасно управлять нативной памятью без использования Unsafe. Это особенно полезно для приложений с высокой производительностью, которые взаимодействуют с C-библиотеками.
🔗 Документация (https://docs.oracle.com/en/java/javase/21/docs/api/java.base/java/lang/foreign/MemorySegment.html)
👩💻
@javaquiz
MemorySegment.allocateNative() из Java Foreign Function & Memory API (FFM API, начиная с Java 19) предоставляет возможность безопасно управлять нативной памятью без использования Unsafe. Это особенно полезно для приложений с высокой производительностью, которые взаимодействуют с C-библиотеками.
🔗 Документация (https://docs.oracle.com/en/java/javase/21/docs/api/java.base/java/lang/foreign/MemorySegment.html)
👩💻
@javaquiz
⚙️ Метод MethodHandles.lookup().findVirtual() позволяет динамически находить и вызывать методы классов без использования рефлексии, что обеспечивает лучшую производительность и безопасность. Это особенно полезно для метапрограммирования и динамических вызовов.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/invoke/MethodHandles.Lookup.html#findVirtual(java.lang.Class,java.lang.String,java.lang.invoke.MethodType))
👩💻
@javaquiz
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/invoke/MethodHandles.Lookup.html#findVirtual(java.lang.Class,java.lang.String,java.lang.invoke.MethodType))
👩💻
@javaquiz
⚙️ VarHandle.compareAndExchange()
VarHandle.compareAndExchange() позволяет безопасно обновлять значения переменной, если текущее значение совпадает с ожидаемым. Это полезно для создания структур данных без блокировок и для синхронизации в многопоточных приложениях.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/invoke/VarHandle.html#compareAndExchange(T,...))
👩💻
@javaquiz
VarHandle.compareAndExchange() позволяет безопасно обновлять значения переменной, если текущее значение совпадает с ожидаемым. Это полезно для создания структур данных без блокировок и для синхронизации в многопоточных приложениях.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/invoke/VarHandle.html#compareAndExchange(T,...))
👩💻
@javaquiz
⚙️ Метод ProcessBuilder.redirectOutput() позволяет перенаправлять стандартный вывод (stdout) запущенного процесса в файл или другой поток. Это очень полезно при взаимодействии с внешними процессами и для логирования их вывода.
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/ProcessBuilder.html#redirectOutput(java.io.File))
👩💻
@javaquiz
🔗 Документация (https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/lang/ProcessBuilder.html#redirectOutput(java.io.File))
👩💻
@javaquiz
⚙️ JMH (Java Microbenchmark Harness)
JMH — это эффективная библиотека для создания точных микробенчмарков на Java. Она помогает измерять производительность кода, минимизируя ошибки, возникающие из-за JIT-компиляции и оптимизаций JVM.
🔗 Документация (https://openjdk.org/projects/code-tools/jmh/)
👩💻
@javaquiz
JMH — это эффективная библиотека для создания точных микробенчмарков на Java. Она помогает измерять производительность кода, минимизируя ошибки, возникающие из-за JIT-компиляции и оптимизаций JVM.
🔗 Документация (https://openjdk.org/projects/code-tools/jmh/)
👩💻
@javaquiz
⚙️ SecureRandom.getInstanceStrong()
Метод SecureRandom.getInstanceStrong() предоставляет криптографически безопасный генератор случайных чисел, который использует алгоритмы операционной системы. Это особенно полезно для создания ключей, токенов и защиты данных.
👩💻
@javaquiz
Метод SecureRandom.getInstanceStrong() предоставляет криптографически безопасный генератор случайных чисел, который использует алгоритмы операционной системы. Это особенно полезно для создания ключей, токенов и защиты данных.
👩💻
@javaquiz
MappedByteBuffer позволяет отображать файлы в оперативную память, что ускоряет процесс чтения и записи больших файлов, при этом снижая нагрузку на оперативную память.
👩💻
@javaquiz
👩💻
@javaquiz
⚙️ Метод ByteBuffer.order() позволяет задавать порядок байтов (Big-Endian или Little-Endian) при работе с бинарными данными. Это полезно при взаимодействии с файлами, сетевыми протоколами и нативным кодом.
👩💻
@javaquiz
👩💻
@javaquiz
⚙️ Метод Thread.getAllStackTraces() позволяет получить информацию о стеке вызовов всех работающих потоков. Это очень полезно для отладки программ, использующих несколько потоков, а также для анализа зависших потоков.
👩💻
@javaquiz
👩💻
@javaquiz
👀 Ограничение использования памяти с помощью -Xmx
В Java есть возможность установить лимит на объём памяти, который будет доступен JVM, чтобы предотвратить избыточное потребление ресурсов и возможные утечки памяти.
✔️ Использование флага -Xmx при запуске позволяет определить максимальный размер кучи (heap size) для Java-программы.
✔️ Также существует возможность установить лимит программно с помощью Runtime.getRuntime().maxMemory().
👩💻
@javaquiz
В Java есть возможность установить лимит на объём памяти, который будет доступен JVM, чтобы предотвратить избыточное потребление ресурсов и возможные утечки памяти.
✔️ Использование флага -Xmx при запуске позволяет определить максимальный размер кучи (heap size) для Java-программы.
✔️ Также существует возможность установить лимит программно с помощью Runtime.getRuntime().maxMemory().
👩💻
@javaquiz
👀 Отслеживание использования памяти с помощью MemoryMXBean
В Java есть возможность контролировать текущее потребление памяти в JVM с помощью MemoryMXBean. Это важно для выявления утечек памяти и анализа работы сборщика мусора.
✔️ С помощью ManagementFactory.getMemoryMXBean() можно получить данные о потреблении памяти в режиме реального времени.
👩💻
@javaquiz
В Java есть возможность контролировать текущее потребление памяти в JVM с помощью MemoryMXBean. Это важно для выявления утечек памяти и анализа работы сборщика мусора.
✔️ С помощью ManagementFactory.getMemoryMXBean() можно получить данные о потреблении памяти в режиме реального времени.
👩💻
@javaquiz
⚙️ Thread.sleep(Duration)
Thread.sleep(Duration) (Java 9+) дает возможность приостанавливать выполнение потока на определенное время, используя Duration, что делает код более понятным и удобным.
👩💻
@javaquiz
Thread.sleep(Duration) (Java 9+) дает возможность приостанавливать выполнение потока на определенное время, используя Duration, что делает код более понятным и удобным.
👩💻
@javaquiz