Java.evolved: Java has evolved. Your code can too

(javaevolved.github.io)

63 points | by jongalloway2 2 days ago ago

36 comments

  • gzread a day ago ago

    Not many people know this, but you can also write

        public int x, y;
    
    instead of

        private int x, y;
        public int getX() {return x;}
        public void setX(int x) {this.x = x;}
        public int getY() {return y;}
        public void setY(int y) {this.y = y;}
    
    this is compatible with any language version
    • brunoborges 18 hours ago ago

      In many cases, yes, public fields are fine. But there are limitations:

      - Can't synchronize access. `synchronized` keyword is not applicable to fields, only to methods and code blocks.

      - Can't proxy. Not possible in public fields, therefore can't intercept calls before state is changed. This is useful for example in mocking frameworks, and telemetry libraries.

      - Can't evolve. Methods allow encapsulation, which allows evolution of the implementation detail. For code base where the public field is accessible by consumers only within the same code base, this may be fine. But for shared libraries, it can easily become a problem.

      • jaen 15 hours ago ago

        but...

        1. Synchronizing on trivial properties (otherwise you couldn't use `public` anyway!) is an anti-pattern, as it's a too fine-grained unit of concurrency and invites race conditions.

        2. Can't proxy without rewriting byte code, you mean.

        3. Of course you can evolve, it's just a breaking ABI change so it requires a trivial code migration on the side of the callee. If the cost of that migration is too high, something else is wrong.

        • uniq7 8 hours ago ago

          > a trivial code migration on the side of the callee

          If your library is used by multiple consumers, forcing all them to migrate is not trivial, no matter how simple the change is.

          If your income comes from these customers, it is not a good idea to put every one of them in the situation of having to choose between updating their code or stoping being your customer.

    • happymellon a day ago ago

      And the second you have anything other than a toy application you'll find out why getters, setters, and validation were invented, and why we them just moved everything to have consistent interfaces.

      • tadfisher a day ago ago

        This is the meme where the Padawan exposes public fields, the intermediate says you must use setters and getters, and the Jedi just exposes public fields.

        (Records kind of made this moot, and for the better)

        • happymellon a day ago ago

          Except records are immutable and have getters and setters as builtins to replicate what we've been doing with Lombok.

          So enforces what I was saying.

          • brunoborges 18 hours ago ago

            To be clear, Records don't have setters. They are immutable.

          • throwA29B 19 hours ago ago

            >immutable

            >setters

            sigh

      • dwroberts 20 hours ago ago

        I think getters and setters had more value when IDEs and refactoring tools were worse (or non-existent).

        A free-for-all accessing some public field is now less of a risk because it’s trivial to find all references and change them.

      • jghn 16 hours ago ago

        Have worked on many a non-toy java application. Have never used things like Lombok hiding getters/setters behind the covers. Never found this to be a real world problem.

    • stuaxo a day ago ago

      I'm from the ancient years of Java, surely this must have started at some point ?

      Do you get getters and setters ?

      I left Java around version 5.

      • jghn 16 hours ago ago

        The more modern take is to not bother with getters & setters for most things. People were cargo-cutting getters/setters on every variable without thinking about the implications.

        First off, there's the question of if most things should even *allow* updates or just be immutable.

        Second, what's the discernable difference between `public final int foo` and `private final foo` w/ `public int getFoo()`. Nothing really. The claim was always "but what if you want to update `foo` to be something more complex? The pain that these advocates always suggested never really wound up being much of a real world problem.

        • leapingdog 15 hours ago ago

          Anything relying on beans for (de)serialization via reflection (XML; JSON) were the big incentive in the J2EE space if I recall correctly.

          • jghn 8 hours ago ago

            Yes. And I believe it kept going with Spring.

            But those were mistakes imposed by frameworks. Not a necessity for good language usage.

      • leapingdog 16 hours ago ago

        Records [0] are a modern form of data transfer object. They are immutable though.

        [0] https://docs.oracle.com/en/java/javase/17/language/records.h...

    • a day ago ago
      [deleted]
  • john-aj a day ago ago

    Great idea, although it is quite inconvenient that you have to tap/swipe to show the modern version (at least on mobile). Makes it difficult to compare.

    • a day ago ago
      [deleted]
    • brunoborges a day ago ago

      Hey mate, what UX would you suggest? Happy to explore ideas!

      For a better visualization to compare old/new, just click on the card and it will open that particular pattern in a new page.

      • javaUIevolved a day ago ago

        Can you add a page where its just a list of all of them in a format like that? https://imgur.com/a/iO42lrs

        I would love to just scroll through a page without having to click on individual cards to see both side by side.

        Love the overall idea of what you did!

      • millerm 19 hours ago ago

        As others have stated, there is no point in a "reveal". Simply show the comparison upfront. User interaction should not be necessary as it only needs to be a plain old html document. You didn't need to write any script. When I got through a bit of it, I wasn't sure if I accidentally skipped something or missed a nuance.

      • hyperhello a day ago ago

        What are you hiding information for? Just show both modes at the same time.

      • kpozin a day ago ago

        Maybe `ArrowLeft`/`ArrowRight` or `j`/`k` to flip through all of card pairs? Or just allow us to scroll through all the pairs. In either case, both old and new should be visible.

      • Traubenfuchs a day ago ago

        Click to toggle. Hard to go back to „old“ version on mobile.

  • nkzd a day ago ago

    Why is "modern approach" changing user threads to virtual threads?

    • brunoborges 18 hours ago ago

      To not worry about system threads. Just create VTs freely without concerns with memory, pooling, etc.

  • 21 hours ago ago
    [deleted]
  • ekropotin a day ago ago

    Cool. Java is catching up with Kotlin at last

    • bzzzt a day ago ago

      Some of the improvements on that site were introduced in Java more than a decade ago.

      Your attitude is exactly why I don't want to have to deal with the Kotlin ecosystem. The difference between Java and Kotlin in 2026 is negligible and the benefits don't weigh up to having to listen to Kotlin evangelists proclaiming it's superior the whole time.

  • ggrab a day ago ago

    Anyone else getting annoyed by these statistics AI generated websites are adding to everything? Like in this example, “0 lines of Python”. What does that even mean? Cool site though, but is it an ad for Copilot? Seems like it, and should be disclosed as such if that’s the case imo.

  • pshirshov a day ago ago

    What's still missing:

    - typeclasses/implicits

    - HKTs

    - for comprehension

    - macros/quasiquotes powerful enough to implement my custom reflection