A munkámból adódóan sok vállalatnál megfordulok és azt látom, hogy a legtöbb helyen még mindig csak a Java 6-os verzióját használják annak ellenére, hogy 2014 március óta már a Java SE 8 is elérhető. Habár a hivatalos roadmap szerint a Java SE 7 publikus frissítései csak 2015 áprilisig várhatóak, érdemes a legfontosabb újdonságokat megismerni, mert azok természetesen a Java SE 8 verzióban is használhatók. Ezekből feature-ökből gyűjtöttem most össze néhányat.
1. Numerikus literáloknál aláhúzásjel használata
Az aláhúzásjelek használatának a célja, hogy megkönnyítse a számok olvashatóságát.
2. String használata switch szerkezetben
A String equals() metódusával lesz kiértékelve a kifejezés. Érdemes tudni, hogy a Java compiler hatékonyabb bytekódot generál ebben az esetben, mintha az if-else szerkezetet használnánk!
3. Erőforrások automatikus lezárása (try-with-resource)
Az erőforrások automatikusan lezárásra kerülnek, ha a try-with-resource szerkezetben, AutoCloseable vagy a Closeable interfészt implementáló osztályokat használunk.
4. Multi Catch
A kód duplikáció elkerülése miatt hasznos, amikor ugyanazt a kivétel lekezelő műveletet szeretnénk használni unrelated kivételek esetén, anélkül hogy a közös ősüket kellene elkapnunk.
5. Precise ReThrow
Nem kapunk fordítási hibát annak ellenére, hogy a kivétel lekezelő ágban feldobott e objektum általánosabb, mint a throws-nál deklarált FileNotFoundException, mivel a fordító képes meghatározni, hogy a kivétel aktuális típusa ebben az esetben FileNotFoundException lesz.
6. Diamond operátor használata
Az olvashatóság megkönnyítése érdekében, a jobb oldalról elhagyhatjuk a generikus típus paramétereket a <> operátor kiírásával.
Az aláhúzásjelek használatának a célja, hogy megkönnyítse a számok olvashatóságát.
class Numbers { public static void main(String args[]) { int i = 1_000_000; long m = 9_999_999_999_999L; double pi = 3.14_15; } }
2. String használata switch szerkezetben
A String equals() metódusával lesz kiértékelve a kifejezés. Érdemes tudni, hogy a Java compiler hatékonyabb bytekódot generál ebben az esetben, mintha az if-else szerkezetet használnánk!
class StringSwitch { public static void main(String args[]) { String fruit = "apple"; switch (fruit) { case "orange": System.out.println("orange"); break; case "apple": System.out.println("apple"); break; case "banana": System.out.println("banana"); break; } } }
3. Erőforrások automatikus lezárása (try-with-resource)
Az erőforrások automatikusan lezárásra kerülnek, ha a try-with-resource szerkezetben, AutoCloseable vagy a Closeable interfészt implementáló osztályokat használunk.
import java.io.BufferedReader; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.PrintWriter; class TryWithResousrce { public static void main(String args[]) throws IOException { try (BufferedReader br = new BufferedReader( new FileReader("c:/temp/myfile.txt")); PrintWriter pw = new PrintWriter( new FileWriter("c:/temp/myfile.txt"))) { pw.println("mytext"); pw.flush(); System.out.println(br.readLine()); } } }
4. Multi Catch
A kód duplikáció elkerülése miatt hasznos, amikor ugyanazt a kivétel lekezelő műveletet szeretnénk használni unrelated kivételek esetén, anélkül hogy a közös ősüket kellene elkapnunk.
import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; class MultiCatch { public static void main(String args[]) { try { BufferedReader br = new BufferedReader(new FileReader("myfile.txt")); Connection con = DriverManager .getConnection("jdbc:postgresql://myhost/db","u","p"); } catch (IOException | SQLException ce) { //handle exceptions } } }
5. Precise ReThrow
Nem kapunk fordítási hibát annak ellenére, hogy a kivétel lekezelő ágban feldobott e objektum általánosabb, mint a throws-nál deklarált FileNotFoundException, mivel a fordító képes meghatározni, hogy a kivétel aktuális típusa ebben az esetben FileNotFoundException lesz.
import java.io.FileNotFoundException; public class PreciseReThrow { public static void main(String args[]) throws FileNotFoundException { try { throw new FileNotFoundException(); } catch (Exception e) { throw e; } } }
6. Diamond operátor használata
Az olvashatóság megkönnyítése érdekében, a jobb oldalról elhagyhatjuk a generikus típus paramétereket a <> operátor kiírásával.
import java.util.ArrayList; import java.util.List; import java.util.Map; public class DiamondUsage { public static void main(String args[]) { List<String> list1 = new ArrayList<>(); List<Map<Integer,List<Double>>> list2 = new ArrayList<>(); } }Persze a lista koránt sem teljes, érdemes még megismerni a NIO 2, a Concurrency API és a JDBC 4.1 újdonságait is mert hasznosak lehetnek a munkánk során és az 1Z0-804 vizsgán is kérdezhetik! .)