В этой статье собраны 7 каверзных вопросов, которые могут застать врасплох даже опытных разработчиков. Они проверяют не только знания языка, но и понимание его глубинных концепций.
Например, что произойдет, если вызвать return или System.exit() в блоке try/catch? Или почему Java не поддерживает множественное наследование?
Разбор этих вопросов поможет лучше подготовиться к собеседованию и избежать неожиданных ловушек.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7😁2
В Java wildcard ? extends T и ? super T используются в обобщённых коллекциях. Запомнить их просто с правилом PECS:
import java.util.List;
import java.util.ArrayList;
public class PECSExample {
// Метод, который работает с продюсерами (Producer Extends)
public static void printNumbers(List<? extends Number> list) {
for (Number num : list) {
System.out.println(num);
}
}
// Метод, который работает с потребителями (Consumer Super)
public static void addNumbers(List<? super Integer> list) {
list.add(10);
list.add(20);
}
public static void main(String[] args) {
List<Integer> intList = List.of(1, 2, 3);
printNumbers(intList); // Можно передавать List<Integer>, List<Double> и т.д.
List<Number> numList = new ArrayList<>();
addNumbers(numList); // Можно передавать List<Number> или List<Object>
System.out.println(numList); // Вывод: [10, 20]
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
1👍13❤3
В этой статье разберем, как правильно экранировать символы, какие escape-последовательности бывают и как их использовать на практике. А еще заглянем в историю этого механизма!
Полезный материал для тех, кто хочет лучше понимать работу строк в Java!
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥4👍2❤1
Please open Telegram to view this post
VIEW IN TELEGRAM
🤣10❤3
Stream API позволяет легко группировать элементы коллекций с помощью Collectors.groupingBy().
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class StreamGroupingExample {
public static void main(String[] args) {
List<String> names = List.of("Анна", "Иван", "Петр", "Ольга", "Алексей", "Игорь");
// Группируем имена по первой букве
Map<Character, List<String>> groupedNames = names.stream()
.collect(Collectors.groupingBy(name -> name.charAt(0)));
System.out.println(groupedNames);
// Вывод: {А=[Анна, Алексей], И=[Иван, Игорь], П=[Петр], О=[Ольга]}
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7🔥2❤1
В лямбда-выражениях удобно находить минимальное и максимальное значения с помощью Comparator.
import java.util.List;
import java.util.Comparator;
public class LambdaMinMaxExample {
public static void main(String[] args) {
List<Integer> numbers = List.of(10, 25, 3, 47, 8);
int min = numbers.stream().min((a, b) -> a - b).orElseThrow();
int max = numbers.stream().max((a, b) -> a - b).orElseThrow();
System.out.println("Минимум: " + min); // Вывод: 3
System.out.println("Максимум: " + max); // Вывод: 47
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9❤3
В Java Comparator позволяет удобно находить минимальные и максимальные значения в коллекциях.
import java.util.List;
import java.util.Comparator;
public class ComparatorMinMaxExample {
public static void main(String[] args) {
List<Integer> numbers = List.of(10, 25, 3, 47, 8);
int min = numbers.stream().min(Comparator.naturalOrder()).orElseThrow();
int max = numbers.stream().max(Comparator.naturalOrder()).orElseThrow();
System.out.println("Минимум: " + min); // Вывод: 3
System.out.println("Максимум: " + max); // Вывод: 47
}
}
💡 Запомни:
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
Please open Telegram to view this post
VIEW IN TELEGRAM
😁14🤣4❤2😭2
В этой статье разберём, какие проблемы могут возникнуть при переносе сервисов между архитектурами x86/64 и ARM из-за различий в моделях памяти. Узнаем, как барьеры памяти помогают управлять многопоточностью и какие подводные камни могут ожидать разработчиков.
Автор подробно объясняет, что такое модели памяти и барьеры памяти, делится личным опытом и предлагает визуально понятные материалы для глубокого понимания темы.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4🤯3❤2
В Java класс Optional помогает избежать NullPointerException и делает код читаемым и безопасным.
import java.util.Optional;
public class OptionalExample {
public static void main(String[] args) {
Optional<String> name = getName();
// Используем ifPresentOrElse
name.ifPresentOrElse(
n -> System.out.println("Имя: " + n),
() -> System.out.println("Имя отсутствует")
);
}
public static Optional<String> getName() {
return Math.random() > 0.5 ? Optional.of("Алиса") : Optional.empty();
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9❤1
Map: Группировка данных с Collectors.groupingBy()
В Java можно группировать данные в Map, используя Collectors.groupingBy().
📌 Пример:
🔹 Разбор:
✔️ groupingBy() — группирует данные по ключу.
✔️ word.charAt(0) — используем первую букву слова как ключ.
✔️ В результате получается Map<Character, List<String>>.
💡 Запомни:
✔️ groupingBy() удобно использовать для агрегации данных.
✔️ Можно комбинировать с mapping() для преобразования значений.
📍 Теги: #java #stream #collectors #groupingBy #collections
В Java можно группировать данные в Map, используя Collectors.groupingBy().
import java.util.*;
import java.util.stream.Collectors;
public class GroupingExample {
public static void main(String[] args) {
List<String> words = List.of("apple", "banana", "avocado", "blueberry", "cherry");
Map<Character, List<String>> groupedWords = words.stream()
.collect(Collectors.groupingBy(word -> word.charAt(0)));
System.out.println(groupedWords);
}
}
✔️ Вывод:
{a=[apple, avocado], b=[banana, blueberry], c=[cherry]}
🔹 Разбор:
Please open Telegram to view this post
VIEW IN TELEGRAM
🤩5👍3❤1
Java предоставляет разработчикам удобные инструменты для сериализации объектов. Несмотря на то, что они кажутся донельзя примитивными, их внутренняя реализация содержит много интересных моментов.
В этой статье мы рассмотрим основы сериализации и некоторые нюансы, связанные с ней. И, конечно, посмотрим, как она работает изнутри.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤2
Recursion vs Iteration: Что выбрать?🗳
Рекурсия и итерация — два способа решения задач. Какой выбрать?
📌 Факториал: Рекурсия vs Итерация
✔️ Рекурсия:
✔️ Итерация:
👍 Разбор:
✔️ Рекурсия удобна для разделяй и властвуй, но может вызвать StackOverflowError.
✔️ Итерация эффективнее по памяти, но иногда менее читаема.
✔️ В Java лучше избегать глубоких рекурсий из-за ограниченного стека.
💡 Запомни:
✔️ Рекурсия = удобство, но риск StackOverflowError.
✔️ Итерация = производительность и безопасность.
📍 Теги: #java #recursion #iteration #performance #bestpractices
Рекурсия и итерация — два способа решения задач. Какой выбрать?
public static int factorialRecursive(int n) {
return (n == 1) ? 1 : n * factorialRecursive(n - 1);
}public static int factorialIterative(int n) {
int result = 1;
for (int i = 2; i <= n; i++) {
result *= i;
}
return result;
}Please open Telegram to view this post
VIEW IN TELEGRAM
👍6❤3🤔3
Please open Telegram to view this post
VIEW IN TELEGRAM
4🔥14😭12❤4
Media is too big
VIEW IN TELEGRAM
В этом видеокурсе автор пошагово и простым языком ознакомит вас с важными концепциями языка Java.
Преподаватель на практике показывает — как, что и зачем делать, прямо в редакторе кода.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍11🤔3🔥1
В Java строки (String) сравниваются не через ==, а с equals(), иначе возможны ошибки.
public class StringComparison {
public static void main(String[] args) {
String s1 = "hello";
String s2 = new String("hello");
System.out.println(s1 == s2); // ❌ false (сравнение ссылок)
System.out.println(s1.equals(s2)); // ✅ true (сравнение значений)
}
}if (s1.equals(s2)) {
System.out.println("Строки равны ");
}Please open Telegram to view this post
VIEW IN TELEGRAM
👍19🤯3❤2
Ошибка: ConcurrentModificationException при итерации по списку.
При изменении ArrayList во время итерации можно получить ConcurrentModificationException.
❌ Ошибка:
👍 Разбор:
✔️ ArrayList использует модификационный счётчик, который ломается при изменении коллекции во время итерации.
✔️ for-each использует Iterator, который не поддерживает удаление элементов во время итерации.
✔️ Правильный вариант 1: Использовать Iterator.remove()
✔️ Правильный вариант 2: Использовать removeIf()
💡 Запомни:
✔️ for-each нельзя использовать для удаления элементов.
✔️ Используй Iterator.remove() или removeIf().
❓ А вы знали об этом?
📍 Теги: #java #concurrentmodification #collections #mistakes #bestpractices
При изменении ArrayList во время итерации можно получить ConcurrentModificationException.
❌ Ошибка:
import java.util.*;
public class ConcurrentModExample {
public static void main(String[] args) {
List<Integer> numbers = new ArrayList<>(List.of(1, 2, 3, 4, 5));
for (Integer num : numbers) {
if (num % 2 == 0) {
numbers.remove(num); // ❌ ConcurrentModificationException
}
}
}
}
Iterator<Integer> iterator = numbers.iterator();
while (iterator.hasNext()) {
if (iterator.next() % 2 == 0) {
iterator.remove(); // Работает корректно
}
}
numbers.removeIf(n -> n % 2 == 0); // Удаляет без исключений
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥12❤7👍5😭1
Ошибка: Автоупаковка (Autoboxing) и производительность.
В Java Integer, Double и другие обёртки примитивов (wrapper classes) используют автоупаковку (autoboxing), которая может снижать производительность.
❌ Ошибка:
Проблема:
🚨 На каждой итерации создаётся новый объект Integer, что замедляет программу!
✔️ Правильный вариант:
👍 Разбор:
✔️ Автоупаковка создаёт новые объекты, что увеличивает потребление памяти и замедляет код.
✔️ Используй примитивные типы (int, double) там, где не нужна обёртка.
💡 Запомни:
✔️ int быстрее, чем Integer.
✔️ Избегай ненужной автоупаковки в циклах.
❓ А вы знали об этом?
📍 Теги: #java #autoboxing #performance #mistakes #bestpractices
В Java Integer, Double и другие обёртки примитивов (wrapper classes) используют автоупаковку (autoboxing), которая может снижать производительность.
❌ Ошибка:
public class AutoboxingExample {
public static void main(String[] args) {
Integer sum = 0; // ❌ Используем обёртку вместо int
for (int i = 0; i < 1_000_000; i++) {
sum += i; // ❌ Автоупаковка на каждой итерации (int → Integer)
}
System.out.println(sum);
}
}Проблема:
int sum = 0; // Используем int
for (int i = 0; i < 1_000_000; i++) {
sum += i;
}
System.out.println(sum);
Please open Telegram to view this post
VIEW IN TELEGRAM
👍19❤5
Please open Telegram to view this post
VIEW IN TELEGRAM
😁35😭5😎4❤1
Дан массив целых чисел и целевое число target. Нужно найти два числа, сумма которых равна target, и вернуть их индексы.
Гарантируется, что решение всегда существует.
Input: nums = [2, 7, 11, 15], target = 9
Output: [0, 1] // (2 + 7 = 9)
Input: nums = [3, 2, 4], target = 6
Output: [1, 2] // (2 + 4 = 6)
import java.util.HashMap;
import java.util.Map;
public class TwoSum {
public static int[] findTwoSum(int[] nums, int target) {
Map<Integer, Integer> map = new HashMap<>();
for (int i = 0; i < nums.length; i++) {
int complement = target - nums[i];
if (map.containsKey(complement)) {
return new int[]{map.get(complement), i};
}
map.put(nums[i], i);
}
throw new IllegalArgumentException("Решение не найдено");
}
public static void main(String[] args) {
int[] nums = {2, 7, 11, 15};
int target = 9;
int[] result = findTwoSum(nums, target);
System.out.println("[" + result[0] + ", " + result[1] + "]");
}
}
Please open Telegram to view this post
VIEW IN TELEGRAM
👍12❤3