"When people ask me what feature do I most regret, serialization is the easy answer" - @BrianGoetz

Let's talk about serialization in Java: Why does it exist? What are the problems (even today)? Would Java have been better off without it? Can it be fixed?

1/11
NB: What follows is mostly quotes or paraphrasing from a conversation I had with Brian during my 25-hour live stream. If you want to watch the full discussion about serialization, nullability, primitives, and more, you can find it here:

2/11
Serialization was introduced because turning an object graph into bytes is valuable: You can store things on disk, in databases, or send them over the wire. But while the concept is sound, it was implemented in a horrible way.

"I wasn't on the team at the time" - Brian

3/11
Serializable objects have three aspects:

1. internal representation (mostly fields)
2. API (public members)
3. external form

With serialization, 1. and 3. are identical by default. One problem is that custom 3. is cumbersome (nipafx.dev/java-serializa… or `Externalizable`).

4/11
Another problem is that serialization bypasses the constructor (to allow serializing circular object graphs). As a result, it exists outside the language and outside the object model (thus often called "extralinguistic").

"The magic is where the sin was." - Brian

5/11
So why was it implemented this way?

* serializing circular graphs is tough
* the language didn't have features suitable for an "intralinguistic" solution
* usual project pressures
* foresight isn't 20/20

And this has not been without consequences...

6/11
Its extralinguistic character is why serialization undermines encapsulation, hinders evolving code, causes security issues, and holds back new Java features.

"Serialization is a full-employment act for vulnerability engineers" - @stuartmarks

7/11
Add to that how rarely it's used today and it makes sense to wonder, would Java have been better off without it?

Brian suspects it wouldn't. Java first became strong on the server side and serialization was essential for distributed object frameworks like EJB or RMI.

8/11
For desktop apps, being able to reliably read/write state from/to disk without having to create code for it can be very valuable as well. One promise of OOP was that reflection would largely automate persistence.

"That was amazing!" - Brian

9/11
So without releasing serialization in late 90s, Java may not have been successful and we may not have this conversation today. Indeed, today's problems come from yesterday's solutions.

How can we solve this one?

10/11
By using more powerful language features (starting with records) and accepting a smaller feature set (no circular graphs), there may be a much more sensible serialization mechanism in Java's future.

I'm looking forward to what Brian and the other JDK devs come up with!

11/11

• • •

Missing some Tweet in this thread? You can try to force a refresh
 

Keep Current with Nicolai Parlog

Nicolai Parlog Profile picture

Stay in touch and get notified when new unrolls are available from this author!

Read all threads

This Thread may be Removed Anytime!

PDF

Twitter may remove this content at anytime! Save it as PDF for later use!

Try unrolling a thread yourself!

how to unroll video
  1. Follow @ThreadReaderApp to mention us!

  2. From a Twitter thread mention us with a keyword "unroll"
@threadreaderapp unroll

Practice here first or read more on our help page!

More from @nipafx

27 Jan
Project Amber is making progress on pattern matching in #JavaNext. Here are three recent developments that I'm very excited about and I think you will be as well.

(Caveats: these are ongoing discussions; none of this is final; speculation and strawman syntax ahead)
1. "Array patterns" allow matching and destructuring arrays. The `if`-line does three things:

a) is `objects` a `String` array with length 2?
b) if so, cast it to `String[]` and extract the two elements
c) declare `a` and `b` and assign the two elements to them
"Can I also bind the arrays as a whole?"

Likely. This is called an "as pattern".

"What if the array can have more elements?"

Allowing to express "at least two elements" is being considered - for example with three dots.
Read 11 tweets
10 Jun 20
Yesterday evening, we spent about two hours digging through the German #Corona app and I'm thoroughly impressed. This is a modern project, developed out there as free software (APL 2.0) on GitHub, and it has stellar documentation.

github.com/corona-warn-app

Let's have a look! 1/🧵 Simplified architecture diagram of the Corona App including the backend services.
Android and iOS apps use Google's/Apple's Exposure Notification Framework (ENF; google.com/covid19/exposu…, apple.com/covid19/contac…). Android app is written in Kotlin, iOS app in Swift. (Can't tell you much more because I'm clueless about mobile.)

2/22
Backend services:

* Java 11, Maven, Sonar, Jenkins
* Open Shift, Kubernetes, Docker
* Postgres, H2, Liquibase
* Spring Boot, Lombok, Protobuf, Guava
* JUnit 4, Hamcrest, Mockito

3/22
Read 24 tweets
2 Sep 19
The electoral swing analysis ("Wählerwanderung") of yesterday's state elections in Germany (e.g. @diezeit, zeit.de/politik/deutsc…) is pretty interesting and I want to comment on who switched to the radical right-wing #AfD.

🖗 Thread
All numbers are relative swing from [voters of $party in 2014 who voted in 2019] to [voters of AfD in 2019] for Sachsen / Brandenburg, i.e. "the usual numbers" normalized by 2019 voters.

In order of their share lost to #AfD, here are the big parties and then former non-voters...
🔵 #AfD: 92.5% / 91.8%

It's pretty obvious that there's no arguing with extremists. Retaining ~90% of voters from one election to the next is "impressive", even for the traditionally stubborn right part of the political spectrum.
Read 15 tweets
20 Dec 17
I just got my (electronic) copy of #EffectiveJava3E and am reading the new parts. Will tweet a little about it...
Nothing spectacular going on with Optional (of course I started with that, what did you think?!) until close to the end. "Optional fields are a smell, but here's an example, where it's justified".

HarHar, I'm just gonna leave this here: blog.codefx.org/java/stephen-c…

#EffectiveJava3E
(Yes, it took me three tries to get that tweet right.)
Read 19 tweets

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just two indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3/month or $30/year) and get exclusive features!

Become Premium

Too expensive? Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal Become our Patreon

Thank you for your support!

Follow Us on Twitter!