Alex cleverly avoided talking about many of the controversial issues, like closures or no closures, and instead focused on what is good language design and how to grow a language, as well as some of the smaller uncontested features that are almost certain to be included. All in all I thought it was a good approach, and a discusson on closures was done in other talks later in the week.
So, to the language features he presented as almost certain to be included in the next version. The first thing he mentioned was that they were adding the possibility to switch on strings. Today this is not possible (only works with enums, byte, short, char and int), and is really a nice addition to the language.
Next up was the possibility of multi-catch of exceptions. This will be very useful when you have to catch several exception and perform the same task. Today the solution would be to have repeated separate catch blocks and then call the same method for each catch block, while the new proposal allows catching multiple types in the same block.
This code:
try {...}
catch (X1 e) {foo();}
catch (X2 e) {foo();}
catch (X3 e) {foo();}
will turn into this
try {...}
catch (X1,X2 e) {foo();}
catch (X3 e) {bar();}
Connected with this, is the possibility for safe re-throw, where the catch block will now allow re-throw of the same type that was caught. For example
catch(final Throwable e)that is really NullPointerException for instance will rethrow NullPointerException. Today, the rethrown exception will be Throwable, which is not good.
Modularity in the language is another big thing. JSR 277 proposes a module system that is included in the language to provide similar functionality to what you can get with OSGi today. A core package like com.statoil.jef.core can be a module, and introduces an accessibility level of classes and methods within a module. Will enable both package private and module private. Adding annontations for metadata like versioning of modules. The main advantage over OSGi is that it is in the languague and things like javadoc and javap will understand the module concept. It has unfortunately many disadvantages over OSGi, and the JSR 277 work is only meant as a starting point. More of the features of OSGi are planned to be included in later versions.
Then a demo was given about some of the additions to the Java annotation system. JSR-308 proposes several extensions to the annotation system ment to provide better compile-time type checking.
- Allow annontations in other places than declarations.
- Pluggable type systems, that you can define to your specific needs, plug into the compiler, and use.
Alex then rounded off the talk with a discussion about the long term evolution of Java, areas of interest and of non-interest. This is a very interesting part, since it hits at what will be considered for future versions. The main message was (as I understood it), that even if something is not included in the Java language, it doesn't mean it is not on the platform (JVM), with a reference to other languages on the JVM like Groovy, Ruby, Python, Fortress and Scala.
All in all a very enlightening talk.
No comments:
Post a Comment