microJUG – Telegram
microJUG
981 subscribers
155 photos
1 video
2 files
237 links
Мысли о Java.
Основной канал: @miniJUG
Буст: https://news.1rj.ru/str/microJUG?boost
Чат: https://news.1rj.ru/str/micro_JUG
Таблица JEP'ов: https://minijug.org/jeps.html
Download Telegram
В Java 18 появился коммит, который убирает неявную ссылку из анонимного класса в соответствующий внешний класс, если внутренний класс его не использует. Это то, из-за чего раньше настоятельно рекомендовалось использовать лямбды вместо анонимных классов, потому что в лямбдах как раз эти ненужные ссылки не добавляются и объекты внешних классов очищаются вовремя. Теперь же анонимные классы и лямбды будут вести себя одинаково в этом плане. Правда пишут, что это изменение сломало некие тесты в JCK, но это пообещали исследовать и возможно коммит откатывать не придётся.
#java18
Что вы используете в продакшене? (для тех, кто всё ещё на Java 8, проголосуйте за 4-й вариант)
Final Results
48%
Готовый JDK
18%
Готовый JRE
1%
Собираем свой образ через jlink с нужными модулями
33%
Мы всё ещё на Java 8 (или старее)
YouTube-канал Java преодолел планку в 100 тысяч подписчиков. А вы подписаны?
microJUG
В Java 18 появился коммит, который убирает неявную ссылку из анонимного класса в соответствующий внешний класс, если внутренний класс его не использует. Это то, из-за чего раньше настоятельно рекомендовалось использовать лямбды вместо анонимных классов, потому…
Выбрасывание неявной ссылки на внешний класс уже попало в последнюю сборку JDK 18-ea+26. Откатывать, слава богу, ничего не будут. Я проверил, this$0 действительно исчезает, если анонимный класс не использует ссылку. Но есть один нюанс: если класс является Serializable и нету поля serialVersionUID, то ссылка остаётся :(. Например, в таком анонимном классе this$0 будет всё равно присутствовать:

new ArrayList<>() {
...
}

Сериализуемых классов в JDK весьма много. Например, практически все коллекции.

Так что новая оптимизация вылечит далеко не все случаи. А любителям double brace initialization придётся писать вот так, чтобы избежать ссылки:

var list = new ArrayList<>() {public static final long serialVersionUID = 1L;{
add(1); }};

#java18
👍1
Ну что, тестируем реакции в Телеге. Го в комменты 👇

А ещё тестим спойлеры
👍25🔥5😱4🎉3🤮3
😁6👍3😱2
Диаграмма зоопарка классов в проекте #Valhalla (источник).
😱11
Программист провёл интересный эксперимент: он реализовал простой сетевой echo клиент-сервер с 1-секундной задержкой и замерил производительность. Использовал три реализации: NIO, виртуальные нити и традиционные нити OS. Результаты можете посмотреть на графиках выше. NIO выиграло по всем параметрам, но отрыв от виртуальных нитей совсем небольшой. Так что NIO хоть и быстрее/эффективнее, но виртуальные нити гораздо более удобная и простая модель, а это в большинстве случаев гораздо важнее в разработке.
Но мне любопытнее показалось другое наблюдение: нити OS не уступили по пропускной способности виртуальным нитям, если было меньше ~30k соединений! А до ~5k соединений физической памяти они использовали ровно столько же! Что такое 5k соединений? Это не такая уж и маленькая нагрузка.
К чему это я? К тому, что это очередное подтверждение правила про преждевременную оптимизацию. Если вы пишете какой-нибудь простой серверок, где у вас не будет большого одновременного количества клиентов (несколько сотен в среднем и в пике до тысячи), то ничего плохого не будет, если вы его реализуете, используя тупой подход "новый поток на каждое новое соединение". А в качестве бонуса вы получите простоту отладки и читаемость кода. А когда выйдет Loom через пару лет, то вы сможете просто поменять все нити на виртуальные, оставив всю остальную часть кода неизменной. Тем временем вы сможете сконцентрироваться на других более важных бизнес-задачах.

#loom
👍12🔥6
При выполнении каких операций выведется <clinit> при условии, что класс X до этого не был инициализирован?
1. X.f()
2. System.out.println(new X()); 3. System.out.println(X.class); 4. Class.forName(X.class.getName()); 5. System.out.println(X.Y);
Final Results
15%
Только 1 и 2
2%
Только 1, 2 и 3
17%
Только 1, 2 и 4
9%
Только 1, 2, 3 и 4
58%
Во всех
👍6🔥4🤩1
Интересный факт. С Java 1.0 инструкция байткода с опкодом 186 была зарезервирована, но не была использована. Через 16 лет на её место в Java 1.7 встанет invokedynamic.

Прям как в воду глядели.
👍10🤩2
Самый полезный сайт в Интернете 😂
https://howoldisjava8.today/
😁5😢2🎉2🤩2👍1
А вы какой вариант предпочитаете?
#var
😁3
Количество JEP'ов, попавших в релизы Java (с JDK 10 по JDK 18)
🔥3