• Lambda@lemmy.ca
    link
    fedilink
    arrow-up
    0
    ·
    3 days ago

    There are many valid practical reasons to avoid Kotlin in certain circumstances (not the least of which being Russian ties). More tools for Java isn’t necessarily a bad thing. However I don’t really think it works. It reminds me of this blog post: https://www.javacodegeeks.com/2017/02/elvis-not-visit-java.html which I think accurately reflects many of my thoughts about null-safety in Java.

      • Lambda@lemmy.ca
        link
        fedilink
        arrow-up
        0
        ·
        12 hours ago

        Just the historical Russian ties, which is enough for some people/organizations to avoid them. The biggest practical reason is the dependence on tooling. Kotlin is a great language, but loses a lot of its allure when you can’t use an IDE for whatever reason. It makes sense, given that its developed by a company whose main product is IDEs; but it can still be an issue in some circumstances.

    • JADEx@programming.devOP
      link
      fedilink
      arrow-up
      0
      ·
      3 days ago

      Let me correct a misunderstanding. JADEx was created as a Java superset language to strengthen Java’s insufficient null-related type system. In JADEx, Java’s reference types are assumed to be non-null by default, and through the nullability static analysis results provided by JADEx, developers can explicitly choose to mark types as nullable. Because of this, there is no problem using null-safe access operators and the Elvis operator.

      To summarize:

      • Java: All types are nullable; there is no non-null type. Therefore, Elvis operators and null-safe access operators cannot be used.
      • JADEx: Both nullable and non-null types exist. Therefore, Elvis operators and null-safe access operators can be used.
      • Lambda@lemmy.ca
        link
        fedilink
        arrow-up
        0
        ·
        3 days ago

        Good clarification, thank you. I guess it would still require some extra care when interfacing with plain Java libraries, but so does e.g. Kotlin. Cool implementation.