• Kissaki@programming.dev
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    4 months ago

    with this in mind

    With what in mind? Evading NULL?

    Languages that make use of references rather than pointers don’t have this Dualism. C# has nullable references and nullability analysis, and null as a keyword.

    What does your reasoning mean in that context?

    • FizzyOrange@programming.dev
      link
      fedilink
      arrow-up
      0
      ·
      4 months ago

      Languages that make use of references rather than pointers don’t have this Dualism.

      It’s not about references vs pointers. You could easily have a language that allowed “null references” or one that properly separated null pointers out in the type system.

      I agree with your point though, using a special Null value is usually worse than using Option or similar. And nullptr_t doesn’t help with this at all.

    • lysdexic@programming.devOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      4 months ago

      With what in mind? Evading NULL?

      Depends on your perspective. It’s convenient to lean on type checking to avoid a whole class of bugs. You can see this either as avoiding NULL or use your type system to flag misuses.

      Languages that make use of references rather than pointers don’t have this Dualism. C# has nullable references and nullability analysis, and null as a keyword.

      C#'s null keyword matches the monadic approach I mentioned earlier. Nullable types work as a Maybe monad. It’s the same concept shoehorned differently due to the different paths taken by these languages.

      • baseless_discourse@mander.xyz
        link
        fedilink
        arrow-up
        0
        ·
        edit-2
        4 months ago

        as far as I know, C# don’t have proper ergonomic monadic bind as in F# (computation expression), Haskell (do expression), and Ocaml (let*), but I could be wrong.