Какой вы используете JUnit?
Final Results
16%
JUnit 4
76%
JUnit 5
11%
Другой фреймворк
14%
Вообще не пишем тесты
Похоже, что 32-битная версия Java всё: https://openjdk.org/jeps/8303167
👍13🫡11👎1😢1
Ежегодный опрос. Какую версию(-и) Java или язык JVM вы используете на работе?
Final Results
20%
Java 8 или более старую
45%
Java 11
3%
Java 12-16
47%
Java 17
4%
Java 18+
4%
Groovy
3%
Scala
25%
Kotlin
1%
Clojure
👍7✍1
Что-то в последнее время стало так много JEP'ов, что стало нереально держать их в голове одновременно (все эти пятые превью и 100500-е инкубаторы). Поэтому решил для себя составить таблицу, которая всегда была бы под рукой. А потом подумал: а почему бы её не сделать общедоступной?
Поэтому вот: https://minijug.ru/jeps.html
Таблица будет поддерживаться в актуальном состоянии.
Фидбек приветствуется.
Поэтому вот: https://minijug.ru/jeps.html
Таблица будет поддерживаться в актуальном состоянии.
Фидбек приветствуется.
🔥22👍12❤1
Вышел тут пост про то, почему не надо использовать Alpine Linux. Рекомендую почитать и задуматься.
Если лень читать, то вкратце поинт такой: проблемы из-за небольших несовместимостей musl и glibc могут доставлять много хлопот, а выигрыш из-за маленького размера образа это никак не оправдывает.
#alpine
Если лень читать, то вкратце поинт такой: проблемы из-за небольших несовместимостей musl и glibc могут доставлять много хлопот, а выигрыш из-за маленького размера образа это никак не оправдывает.
#alpine
🤔8🌚1
Результаты опроса и выводы:
• Java 17 вырвалась вперёд и обогнала Java 11🥳 .
• Java 18 и 19 заметно выросли, но процент всё ещё ничтожен (никто не хочет юзать STS-релизы).
• Java 8 постепенно умирает.
• Kotlin показывает стабильный рост. Но мне кажется, что это из-за того что грэдлисты переходят с Groovy на Kotlin DSL. Но могу ошибаться. Напишите в комментах, для чего вы юзаете Kotlin (основной язык / Kotlin DSL / Android).
#java8 #java11 #java17 #java18 #java19 #kotlin
• Java 17 вырвалась вперёд и обогнала Java 11
• Java 18 и 19 заметно выросли, но процент всё ещё ничтожен (никто не хочет юзать STS-релизы).
• Java 8 постепенно умирает.
• Kotlin показывает стабильный рост. Но мне кажется, что это из-за того что грэдлисты переходят с Groovy на Kotlin DSL. Но могу ошибаться. Напишите в комментах, для чего вы юзаете Kotlin (основной язык / Kotlin DSL / Android).
#java8 #java11 #java17 #java18 #java19 #kotlin
Please open Telegram to view this post
VIEW IN TELEGRAM
🎉6👍2🤔2
#lilliput #java21
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥7👍4👨💻1
https://openjdk.org/jeps/8303683: This JEP proposes to finalize Virtual Threads in JDK 21
#loom #java21
Please open Telegram to view this post
VIEW IN TELEGRAM
🍾37🎉6👍1
Стюарт Маркс, например: https://youtu.be/NA-sB3zvluE
YouTube
Java Language Futures, Spring 2023 Edition
Through Project Amber, the Java programming language is evolving faster than ever. Watch this video to get an overview of many of the Java language enhancements that have appeared in recent Java versions, including Java 20. You’ll also get a glimpse of the…
✍4🎅1
Please open Telegram to view this post
VIEW IN TELEGRAM
💅8😢5🤡4😁2🤔2💩2👻1
Помните, были такие сырые строковые литералы? Их хотели добавить в Java 12, но потом отказались от этой идеи.
Так вот, эту идею подхватил C# 11. Смысл очень похожий на Java 12: сырой строковый литерал может начинаться с любого количества кавычек (минимум 3), но должен и заканчиваться на то же самое количество. А между этими n-арными кавычками можно вставить любую чухню (главное, чтобы не было n кавычек подряд):
А правило такое: количество долларов контролирует количество фигурных скобок, обрамляющих интерполяцию внутри литерала!
Например:
Теперь вы понимаете, почему в Java так тщательно продумывают новые фичи и неспешно их вводят?
Лучше уж мало фич, но без подобного синтаксического сумасшествия.
#csharp
Так вот, эту идею подхватил C# 11. Смысл очень похожий на Java 12: сырой строковый литерал может начинаться с любого количества кавычек (минимум 3), но должен и заканчиваться на то же самое количество. А между этими n-арными кавычками можно вставить любую чухню (главное, чтобы не было n кавычек подряд):
string raw = """"Но это ещё не всё. В C# ведь ещё есть строковая интерполяция (
Hello, "John"!
""""
$"Hello, {name}!"). Как будут выглядеть сырые строковые литералы с интерполяцией?А правило такое: количество долларов контролирует количество фигурных скобок, обрамляющих интерполяцию внутри литерала!
Например:
string name = "John";Эта строка превратится в:
string raw = $$"""
Hello, {{name}}!
My {name} is {{{name}}}
"""
Hello, John!Т.е. понимаете? Не только количество кавычек произвольное, но и количество долларов! Например, вот такой код является валидным кодом на C# 11:
My {name} is {John}
$$$$$$$$$$$$""""""""""""""""
Hello
""""""""""""""""
Но это ещё не всё. Всё это безумие ещё добавляется к буквальным строковым литералам, которые начинаются с @". Т.е. в C# теперь есть 6 видов литералов: обычные, обычные с интерполяцией, буквальные, буквальные с интерполяцией, сырые и сырые с интерполяцией.Теперь вы понимаете, почему в Java так тщательно продумывают новые фичи и неспешно их вводят?
Лучше уж мало фич, но без подобного синтаксического сумасшествия.
#csharp
🤯19😁7🔥4👍2
В Java 21 появился долгожданный метод
#java21
reversed(), который возвращает view коллекции с обратным порядком:jshell> List.of(1, 2, 3, 4, 5).reversed()
$1 ==> [5, 4, 3, 2, 1]
Этот метод есть у любой коллекции, реализующей интерфейс SequencedCollection (List, Deque, Stack и т.д). Кстати, всё это уже есть в последнем билде JDK 21-ea+20, так что можно затестить.#java21
👍11🎉2👌1🤡1
Самые популярные вендоры OpenJDK в 2023 году:
1. Amazon (31%)
2. Oracle (28%)
3. Eclipse Adoptium (12%)
4. Red Hat (11%)
5. Azul (6%)
6. SAP (3%)
7. BellSoft (1.9%)
8. Debian (1.8%)
Oracle впервые не первый🫡
Источник: What Is the State of the Java Ecosystem in 2023?
1. Amazon (31%)
2. Oracle (28%)
3. Eclipse Adoptium (12%)
4. Red Hat (11%)
5. Azul (6%)
6. SAP (3%)
7. BellSoft (1.9%)
8. Debian (1.8%)
Oracle впервые не первый
Источник: What Is the State of the Java Ecosystem in 2023?
Please open Telegram to view this post
VIEW IN TELEGRAM
🫡10🤔2✍1
Какой, по вашему мнению, самый важный релиз в истории Java, который наибольшим образом продвинул язык и платформу?
(Считаем, как будто STS-релизов вообще не было и выходили только LTS-релизы, содержащие в себе все нововведения из предшествующих STS)
(Считаем, как будто STS-релизов вообще не было и выходили только LTS-релизы, содержащие в себе все нововведения из предшествующих STS)
Anonymous Poll
14%
Java 5 (generics, annotations, enum, autoboxing, enhanced for-loop)
2%
Java 7 (try-with-resources, diamond, switch over strings, multicatch, nio2)
75%
Java 8 (lambdas, streams, default methods, java.time)
2%
Java 11 (modules, var, compact strings, launch single-file source programs)
2%
Java 17 (switch expr, text blocks, records, pm for instanceof, sealed, zgc, shenandoah)
5%
Java 21 (pm for switch/records, loom, sequenced collections, generational zgc)
В исходном коде java.lang.String обнаружили интересный баг, причиной которой является race condition в конструкторах строк, принимающих массивы (byte[], char[] или int[]). Эксплуатируя это состояние гонки, можно получить строки с забавными свойствами, например, что "hello world" не начинается с "hello" или что "foo" не равен "foo". Можно даже получить пустую строку, которая не равна "".
Race condition в конструкторе очень простой и заключается в том, что входной массив читается дважды в разные моменты времени (см. картинку). За то время, пока одно считывание закончилось и началось второе, содержимое массива может поменяться из другого потока.
Багу подвержены все версии JDK, начиная с Java 9 (в которой появились компактные строки). На данный момент неизвестно об уязвимостях, вызванных данных багом. Но кажется, что такие уязвимости со временем появятся, ведь сравнение строк очень частая операция (например, сравнение паролей). В багтрекере OpenJDK баг завели, но сделали приватным, что может намекать, что баг действительно может иметь последствия для безопасности.
Мне очень любопытно, как этот баг будут исправлять. Избежать многократного чтения массива можно путём создания временной копии. Но это сильно просадит производительность при создании строк. На такое явно не пойдут. Скорее всего, будут придумывать другие более изощрённые алгоритмы.
#string
Race condition в конструкторе очень простой и заключается в том, что входной массив читается дважды в разные моменты времени (см. картинку). За то время, пока одно считывание закончилось и началось второе, содержимое массива может поменяться из другого потока.
Багу подвержены все версии JDK, начиная с Java 9 (в которой появились компактные строки). На данный момент неизвестно об уязвимостях, вызванных данных багом. Но кажется, что такие уязвимости со временем появятся, ведь сравнение строк очень частая операция (например, сравнение паролей). В багтрекере OpenJDK баг завели, но сделали приватным, что может намекать, что баг действительно может иметь последствия для безопасности.
Мне очень любопытно, как этот баг будут исправлять. Избежать многократного чтения массива можно путём создания временной копии. Но это сильно просадит производительность при создании строк. На такое явно не пойдут. Скорее всего, будут придумывать другие более изощрённые алгоритмы.
#string
✍10👀10🤔7😁6👍3❤1🔥1