Comment on Is Java Still Keeping Up with Modern Programming Languages
huginn@feddit.it 1 year agoCorporate standards.
I’m pushing for no half measures: it’s Kotlin or bust.
Comment on Is Java Still Keeping Up with Modern Programming Languages
huginn@feddit.it 1 year agoCorporate standards.
I’m pushing for no half measures: it’s Kotlin or bust.
BlueBockser@programming.dev 1 year ago
Definitely agree that Kotlin is so much better than Java + Lombok, but it’ll take a lot of time for all the existing Java projects or migrate to Kotlin or reach EOL. In the meantime, it’s hard to avoid the occasional Java project…
huginn@feddit.it 1 year ago
Sure but you can also just drop kotlin into any Java codebase. It’s a single line maven import and the entire company already uses Intellij
gravitas_deficiency@sh.itjust.works 1 year ago
Oh yeah - the seamless Java/kotlin interop is pretty slick, though there are some pitfalls - nullity is one of them. Kotlin treats it explicitly, but when it’s talking to Java, it’s forced to treat it ambiguously unless you wrap stuff in
Optional
. And then even if you do, some Java lib that you need to plug into your project might not do that, so you’ve got to be careful about managing the interactions between their interfaces in some situations. And then there’s the unfortunate divergence that’s started to occur as newer versions of Java have brought certain features that were first available in Kotlin into Java, but the patterns and interfaces often differ subtly, so you have to worry about that too, especially with less experienced engineers on the team.Don’t get me wrong - it’s great, and I’ve enjoyed working with it, but if you’re doing an incremental migration, make sure you test the ever-loving shit out of it.
Source: I did an incremental Java -> Kotlin migration on a huge project a couple jobs ago
huginn@feddit.it 1 year ago
Yeah it can be slightly hairy because Java does a terrible job with nullability. I’ve also done an incremental migration of an android codebase to Kotlin.
Personally I think being forced to declare the nullability of a field is something backend developers should do more of. It helps eliminate some of the foot guns that otherwise get built into the code base.
I’m a bit of a kotlin fanboy though, I’ll admit.