JEP 359: The Best New Thing for a Long Time for JAVA
In the early weeks of the second quarter of 2019, Brian Goretz who is famously known as the Architect of Java language came up with a JEP draft that proposed a few new additional features to the already rich programming language. Three and half months later, the draft has been polished with all the necessary documents and has finally approved. These are the JEP 359 and the JEP 360.
In this article, we will focus on JEP 359 Records (Preview). Let’s take a closer look at the future of Java via this new feature:
What is JEP after all?
The JDK Enhancement Proposal is a process drafted by Oracle Corporation. It is a platform through which enhancement proposals to the Java programming languages, particularly the Java Web Development Kit and OpenJDK are collected, scrutinized and on meeting certain criteria accepted to the grammar.
To define it in the best way possible, let us understand an explanation offered by Oracle. They define JEP or the Java Enhancement Proposals as the long-term roadmap for JDK Release Projects and related efforts. A JEP is written to impact Java’s core technology and structure. These proposals are enhancements usually that may or may not be ready to be specified yet and thus, need work before they are brought out to the public.
According to the statements in the document of JEP 0, JEPs demand ideas for enhancement and innovation to not only be novel but also impact the general development community. Hence, such type of work will require prototyping to differentiate between a viable and a non-viable JEP so that specification can generate.
Java often criticized as being too wordy and that it has too much ‘ceremony’. It largely affects the classes that only act as data carriers as to write a data carrier-class properly, following which one often encounters a lot of low-value, repetitive, error-prone code. Hence, it becomes more and more important to find a way to write enhancements that help in writing such code more simply and easily (not only to read and write but also to validate).
A new class that is easy clearer and concise with only one function: to declare shallowly-immutable, well-behaved nominal data aggregates – was therefore desirable. The idea might as well look, like just about reducing the boilerplate but it extends much more than that. A more semantic goal was to present data as it should, in the manner that the boilerplate itself could be, taken care.
The main objective of JEP 359 is to introduce a new kind of type declaration called records. Records developed with the responsibility of providing a new syntactical and logical way to declare classes that act as “transparent holders for shallowly immutable data”. As with an enum, restrictions are applied to record classes.
It showcases its representation, and once it finds a proper match, it commits to that API. Records lack a degree of freedom that classes usually enjoy – the ability to decouple a class’s API from representation. Still, one of the benefits is that they can bring about a higher degree of concision. In return, they gain a significant degree of concision. Hence, a record effectively explained as ‘the state, the whole state, and nothing but the state.’
As stated above, in pursuit of concision and security, records have a set of undeniable set of restrictions. A record cannot do everything for, an example they are not allowed to extend classes or declare any instance fields that are other than the private final fields required for state description. The abstraction of the same is restricted and is implicitly final.
It is, of course, to maintain sanity that API of a record is not further enhanced or ‘recorded’ by another specific class. As stated, all the components are implicitly final; that goes on to explain that data aggregate follows the ‘immutable by default’ policy. If we set aside these restrictions, records behave quite like other normal classes.
Another way to look at Records is to define them as a nominal form of tuples. Instead of defining records per se, structural tuples can also implement. However, even if you seem to appreciate the lightweight option of the tuples, they are often not at par with the record in terms of aggregates. The center of Java’s philosophy, as explained by, many pundits is that names do matter. Classes, their components, and the data have a proper naming structure. On the other hand, tuples and their relatives are void of that. Constructors that only classes have also help in-state validation and help in faster data input. Classes stick to the behavior that is set by the state.
The true enhancement of Java has performed with the long-required addition of Records. As aforementioned, Records are the better, faster, and safer way to declare classes which are transparent holders for shallowly immutable data and that too done through a simpler and more compact syntax.
It really doesn't matter which type of business you have what matters the most is which strategy you follow to improve your web presence. Web presence plays a crucial role when it comes to enhancing the customer base and earning more ROI in less time
Construction problems can happen anywhere. And, it normally starts with a small calculation problem or someone that can’t read designs and drawings correctly. The results can be catastrophic with a lot of damage to structures and to vehicles.
You might have heard about the do-dig hydro excavation technology that is making it so much easier at construction sites. Especially when it comes to digging underground and to unclog certain areas.
Therefore as the above-stage adage goes your business probably does (and certainly should) side with your customers- even if they stand out wrong. This is because when any customer voices his/her displeasure; you usually have a good idea as to why they are right or wrong.