tgoop.com/Java_Iibrary/1864
Create:
Last Update:
Last Update:
Представим, что тебе нужно посчитать максимальную зарплату сотрудников по отделам на Java. Код мог бы выглядеть так:
List<Employee> employees = new ArrayList<>();
Map<String, Long> maxMap = new HashMap<>();
for (Employee employee : employees) {
Long maxSalaryForDepartment = maxMap.get(employee.department);
if (maxSalaryForDepartment == null || maxSalaryForDepartment < employee.salary) {
maxMap.put(employee.department, employee.salary);
}
}
Но этот цикл можно записать гораздо короче:
for (Employee employee : employees) {
maxMap.merge(employee.department, employee.salary, Math::max);
}
Метод Map.merge() работает так:
Первый параметр — это ключ, по которому ты хочешь добавить или обновить значение в Map.
Второй параметр — новое значение, которым нужно обновить сохранённое.
Если для этого ключа значение отсутствует (или там null), Map просто сохраняет новое значение.
Третий параметр — это функция. Если в Map уже есть значение для этого ключа, функция вызывается с двумя аргументами: старым и новым значением. То, что вернёт эта функция, и будет записано как новое значение для ключа.