Rilaxx Java SE 20

Wara sitt xhur ta 'żvilupp, Oracle ħareġ il-pjattaforma Java SE 20 (Java Platform, Standard Edition 20), li tuża l-proġett OpenJDK open source bħala implimentazzjoni ta' referenza. Bl-eċċezzjoni tat-tneħħija ta 'xi karatteristiċi deprecati, Java SE 20 iżomm kompatibilità b'lura ma' rilaxxi preċedenti tal-pjattaforma Java - il-biċċa l-kbira tal-proġetti Java miktuba qabel xorta se jaħdmu mingħajr modifika meta jitħaddmu taħt il-verżjoni l-ġdida. Bini ta' Java SE 20 lest biex jiġi installat (JDK, JRE, u Server JRE) huma ppreparati għal Linux (x86_64, AArch64), Windows (x86_64), u macOS (x86_64, AArch64). Żviluppata mill-proġett OpenJDK, l-implimentazzjoni ta' referenza Java 20 hija sors kompletament miftuħ taħt il-liċenzja GPLv2 b'eċċezzjonijiet GNU ClassPath biex tippermetti konnessjoni dinamika ma' prodotti kummerċjali.

Java SE 20 huwa kategorizzat bħala rilaxx ta 'appoġġ regolari, b'aġġornamenti li għandhom jiġu rilaxxati qabel ir-rilaxx li jmiss. Il-fergħa tal-appoġġ fit-tul (LTS) għandha tkun Java SE 17, li se tirċievi aġġornamenti sal-2029. Ifakkar li beda bir-rilaxx ta 'Java 10, il-proġett qaleb għal proċess ta' żvilupp ġdid, li jimplika ċiklu iqsar għall-formazzjoni ta 'rilaxxi ġodda. Funzjonalità ġdida issa qed tiġi żviluppata f'fergħa prinċipali waħda aġġornata kontinwament, li tinkorpora bidliet li diġà tlestew u li minnha fergħat huma ramifikati kull sitt xhur biex jistabbilizzaw rilaxxi ġodda.

Karatteristiċi ġodda f'Java 20 jinkludu:

  • Предложена предварительная поддержка ограниченных значений (Scoped Values), позволяющих совместно использовать неизменяемые данные в потоках и эффективно обмениваться данными между дочерними потоками (значения наследуются). Scoped Values развиваются для замены механизма переменных локальных к потоку (thread-local variables) и более эффективны при использовании очень большого числа виртуальных потоков (тысячи и миллионы потоков). Главное отличие Scoped Values от переменных локальных к потоку в том, что первые записываются один раз, в дальнейшем не могут быть изменены и остаются доступны только на время выполнения потока. class Server { final static ScopedValue CURRENT_USER = new ScopedValue(); void serve(Request request, Response response) { var level = (request. isAuthorized()? ADMIN : GUEST); var user = new User(level); ScopedValue.where(CURRENT_USER, user) .run(() -> Application.handle(request, response)); } } class DatabaseManager { DBConnection open() { var user = Server.CURRENT_USER.get(); if (!user.canOpen()) throw new InvalidUserException(); return new DBConnection(…); } }
  • Добавлена вторая предварительная реализация шаблонов записей (record pattern), расширяющая появившуюся в Java 16 возможность сопоставления с образцом средствами для разбора значений классов типа record. Например: record Point(int x, int y) {} static void printSum(Object obj) { if (obj instanceof Point p) { int x = p.x(); int y = p.y(); System.out.println(x+y); } }
  • Добавлена четвёртая предварительная реализация сопоставления по шаблону в выражениях «switch», позволяющая в метках «case» использовать не точные значения, а гибкие шаблоны, охватывающие сразу серию значений, для которых ранее приходилось использовать громоздкие цепочки выражений «if…else». static String formatterPatternSwitch(Object obj) { return switch (obj) { case Integer i -> String.format(«int %d», i); case Long l -> String.format(«long %d», l); case Double d -> String.format(«double %f», d); case String s -> String.format(«String %s», s); default -> o.toString(); }; }
  • Добавлена вторая предварительная реализация API FFM (Foreign Function & Memory), позволяющего организовать взаимодействие Java-программ с внешними кодом и данными через вызов функций из внешних библиотек и доступ к памяти вне JVM.
  • Добавлена вторая предварительная реализация виртуальных потоков, представляющих собой легковесные потоки, значительно упрощающие написание и сопровождение высокопроизводительных многопоточных приложений.
  • Добавлен второй вариант экспериментального API для cтруктурированного параллелизма, упрощающего разработку многопоточных приложений за счёт обработки нескольких задач, выполняемых в разных потоках, как единого блока.
  • Добавлена пятая предварительная реализация API Vector, предоставляющего функции для векторных вычислений, которые выполняются с использованием векторных инструкций процессоров x86_64 и AArch64 и позволяют одновременно применить операции сразу к нескольким значениям (SIMD). В отличие от предоставляемых в JIT-компиляторе HotSpot возможностей по автовекторизации скалярных операций, новый API даёт возможность явно управлять векторизацией для параллельной обработки данных.

Sors: opennet.ru

Żid kumment