Conosciamo tutti Java per le sue caratteristiche grazie alle quali, nonostante siano passati più di 20 anni dalla prima versione,è tutt'oggi uno dei linguaggi più studiati e più utilizzati, malgrado la crescente diffusione di Python.
Una delle forti pecche rimane comunque il fatto che sia molto prolisso e per anni Oracle non ha dato alcun segni di cambiamento. Finalmente, con la versione 12 qualcosa sembra cambiare. Java sembra muoversi verso un modo di programmare che, in un futuro che sembra ancora lontano, permetta di scrivere codice più compatto senza perdere leggibilità e soprattutto mantenendo la portabilità che ha sempre lo ha sempre contraddistinto.
Vediamo alcune novità importanti.
Miglioramento delle switch expressions
La cosa fondamentale da dire è che questa funzione è stata introdotta come funzione sperimentale nella JEP 325, il che significa che se pur l'implementazione è completa e funzionante, potrebbe non essere riconfermata nelle versioni successive.
Una cosa decisamente interessante è il fatto che il costrutto preveda l'utilizzo della freccia ->.
Quali sono le novità fondamentali?
- Non è necessario usareil break per ogni case;
- Si possono definire diverse costanti per lo stesso case;
- Il caso default è obbligatorio;
- Il break può essere usato per restituire i valori dello switch;
Vediamo un esempio:
String stagione= ""; switch (mese) { case "marzo": case "aprile": case "maggio": { stagione= "primavera"; break; } case "giugno": case "luglio": case "agosto": { stagione= "estate"; break; } };
Mentre ora, con questo nuova sintassi, il medesimo programma diventerebbe:
String stagione=switch(mese){ case "marzo", "aprile", "maggio":{ break "primavera"; } case "giugno", "luglio", "agosto":{ break "estate"; }default ->{ break "altra stagione"; } };
Questa nuova forma di switch, spesso risulta molto comoda, magari in ambito GUI dove potrebbe capitare che diversi tasti facciano la stessa cosa, o abbiano funzioni in comune.
Nuovo modo per confrontare i file: File.mismatch()
La firma del metodo è:
public static long mismatch(Path path, Path path2) throws IOException
L'idea alla base è quella di restituire la distanza tra i due file, restituendo -1L se i file sono uguali. Due file possono essere diversi quando:
- Ci sono dei byte diversi, allora viene restituita la posizione del primo byte diverso;
- La dimensione non è la stessa, quindi viene restituita la minore;
Utile sì, assolutamente sì!
Notazione compatta dei numeri
Veongono introdotti nuovi metodi per la notazione compatta dei numeri a seconda del locale scelto.
public class CompactNumberFormatDemo { private static void esempiCompactNumberFormatting(final long numberToFormat){ final NumberFormat nfDefault = NumberFormat.getCompactNumberInstance(); final NumberFormat nfItShort = NumberFormat.getCompactNumberInstance(Locale.ITALY, NumberFormat.Style.SHORT); final NumberFormat nfItLong = NumberFormat.getCompactNumberInstance(Locale.ITALY, NumberFormat.Style.LONG); final NumberFormat nfFrShort = NumberFormat.getCompactNumberInstance(Locale.FRANCE, NumberFormat.Style.SHORT); final NumberFormat nfFrLong = NumberFormat.getCompactNumberInstance(Locale.FRANCE, NumberFormat.Style.LONG); out.println("Numero da formattare '" + numberToFormat + "':"); out.println("tDefault: " + nfDefault.format(numberToFormat)); out.println("tIT/Short: " + nfItShort.format(numberToFormat)); out.println("tIT/Long: " + nfItLong.format(numberToFormat)); out.println("tFR/Short: " + nfFrShort.format(numberToFormat)); out.println("tFR/Long: " + nfFrLong.format(numberToFormat)); } public static void main(final String[] arguments) { esempiCompactNumberFormatting(15000); } }
Otterremo come risultato:
Numero da formattare '15000':
Default: 15K
IT/Short: 15.000
IT/Long: 15 mila
FR/Short: 15 k
FR/Long: 15 mille
Teeing collector
Il principio di funzionamento è simile a quello del comando tee, familiare agli utenti unix, che redireziona l’input ai due collectors prima di fare il merge dei loro risultati mediante una Bi-function.
var result = Stream.of("Andreas", "Antonia", "Lucia", "Francesco").collect(Collectors.teeing( // primo collector Collectors.filtering(n -> n.contains("c"), Collectors.toList()), // secondo collector Collectors.filtering(n -> n.endsWith("s"), Collectors.toList()), // merger Bi-function (List list1, List list2) -> List.of(list1, list2) )); System.out.println(result); // -> [[Lucia, Francesco], [Andreas]]
JEP 305: Pattern Matching for instanceof (Preview)
Finalmente non è più necessario effettuare il casting esplicito prima di usare un oggetto.
// Prima di java 12 if (obj instanceof String) { String s = (String) obj; // usa s come stringa } // In java 12 e forse anche dopo... if (obj instanceof String s) { // è possibile usare s come stringa direttamente senza bisogno del casting }
Altre novità
- Sono stati introdotti ulteriori metodi per la classe String. Ulteriori informazioni sono reperibili sulla documentazione ufficiale :
- indent(int n);
- transform(Function f);
- Optional describeConstable();
- String resolveConstantDesc(MethodHandles.Lookup lookup);
- Con la JEP334 è stata introdotta una nuova classe java.lang.constant che contiene i descrittori nominali di vari tipi di costanti.
In definitiva, come accennato prima, Java sembra finalmente muoversi verso una sintassi che rende il codice più semplice, anche se le funzioni che appaiono più interessanti rimangono una preview. Personalmente, sono proprio curioso di seguire gli sviluppi di questa versione.
Non avrei mantenuto l'utilizzo delle variabili var, in uso da Java 10, che possono essere non tipizzate un po' sulla falsariga di JavaScript. Nonostante ciò riconosco che talvolta può essere utile anche se le variabili var possono essere utilizzate solo con scope locale. Ad oggi Java continua a non interpretare var come una keyword, quindi una parola dedicata al linguaggio, ma ne riconosce comunque il significato. Chissà, magari con il passare del tempo e delle generazioni di programmatori, l'uso diventerà più frequente e diventerà una keyword.
Parlando di tempistiche, quali sono le date relative alle varie release?
- 13/12/2019 Prima fase di distribuzione
- 17/01/2019 Seconda fase di distribuzione
- 07/02/2019 Rilascio di una versione beta
- 19/03/2019 Disponibilità generale
Vale la pena passare a Java12?
Secondo me, assolutamente sì! In particolare per i programmatori smanettoni che hanno voglia di provare la nuova versione appena arriva. Personalmente, rifarei altre mille volte il passaggio! Ho trovato addirittura qualche miglioramento, penso dovuto al cambio di algoritmo del garbage collector, che si chiama Shenandoah e che non tiene più conto della dimensione dello heap.
Al contrario, per i neofiti potrebbe essere conveniente iniziare con la versione precedente, che è sicuramente più stabile e non ha grandi differenze. Nel momento in cui la versione diventerà stabile con le varie features definitive, sarà sicuramente interessante fare l'upgrade.
Alessio Mungelli
Computer Science student at UniTo (University of Turin), Network specializtion, blogger and writer. I am a kind of expert in Java desktop developement with interests in AI and web developement. Unix lover (but not Windows hater). I am interested in Linux scripting. I am very inquisitive and I love learning new stuffs.
Articoli correlati
Un approccio a Java: switch statement
Ciao a tutti e bentornati! Dopo una pausa, torniamo oggi con un'altra parte del corso introduttivo alla programmazione, parlando di switch statement, conosciuto anche come costrutto di selezione multipla. Intuizione L'idea dello switch statement…
Un approccio a Java: Il ciclo while
Ciao a tutti e bentornati! Dopo aver fatto una breve, ma corposa, introduzione sui cicli, andiamo oggi a vedere finalmente le prime implementazioni che utilizzano quello che abbiamo definito ciclo precondizionale. In Java, come…
Un approccio a Java: I cicli - Introduzione
Ciao a tutti e bentornati! Sino ad ora, abbiamo parlato di variabili e di strutture di selezione, andando a considerare alcuni degli aspetti fondamentali di questi due concetti. Teoricamente, per…
Un approccio a Java: strutture di selezione - casi d'uso
Ciao a tutti e bentornati! Sino ad ora ci siamo preoccupati di fare una carrellata quanto più completa riguardo i concetti fondamentali di cui abbiamo bisogno per approcciarci all'utilizzo delle…
Un approccio a Java: operatori booleani
La volta precedente, abbiamo ampiamente parlato delle variabili booleane, cercando di delineare quali siano le principali operazioni che si possono effettuare proprio a livello pratico. Di tutti i casi esaminati, non abbiamo…
Un approccio a Java: le variabili booleane
Ciao a tutti e bentornati! La volta precedente, ho fatto un'introduzione alle strutture condizionali, definendo il loro funzionamento. Prima di poter dare qualche esempio pratico, è necessario chiarire in che modo ci…
Un approccio a Java: strutture condizionali
Ciao a tutti e bentornati! Le volte precedenti abbiamo introdotto il concetto di variabile, tentando di definire alcuni concetti basilari a riguardo. Alcune situazioni fanno però intuire come il solo concetto…
Un approccio a Java: Le variabili - caso d'uso
Ciao a tutti amici e bentornati! Dopo l'introduzione fatta sulle variabili, cerchiamo di analizzare alcune criticità che si possono presentare in situazioni alquanto comuni. Partiamo quindi analizzando degli esempi pratici. Esempio 1: divisione…
Un approccio a Java: Le variabili
Ciao a tutti e bentornati! Quest'oggi inizieremo un percorso che ci porterà a studiare, ed eventualmente ripassare, quelle che sono le basi della programmazione. Inizieremo parlando di variaibli. Introduzione Chiunque voglia approcciarsi al…
Hashmap con concatenamento: liste di trabocco
In questa breve serie di articoli andremo a vedere com'è possibile realizzare in C la struttura dati Hashmap. Nell'implementazione andremo ad usare le liste doppiamente concatenate come strutture dati ausiliarie. Andiamo…
Java Strutture Dati: Liste Concatenate
Con il 2020 andiamo ad esaminare un nuovo aspetto della programmazione: le strutture dati. Spesso capita a tutti di utilizzare strutture messe a disposizione dai vari linguaggi di programmazione. L'obiettivo sarà…
Java Algoritmi di Ordinamento: Selection Sort
Andiamo oggi ad analizzare in dettaglio un algoritmo di ordinamento non molto efficiente ma piuttosto utilizzato in diversi ambiti. Stiamo parlando del Selection Sort. Vediamo meglio in dettaglio. Intuizione L'idea alla base è quella…