• Troy@lemmy.ca
    link
    fedilink
    arrow-up
    19
    arrow-down
    1
    ·
    1 year ago

    Tl;dr: don’t use @property during design, it’s almost certainly the wrong pattern. But use it to retrofit a method to a value.

    • sugar_in_your_tea@sh.itjust.works
      link
      fedilink
      arrow-up
      2
      ·
      1 year ago

      Yup. I pretty much only use it if I need to ensure new values are valid or provide a default value.

      I do the same in other languages, like C# and JavaScript. Properties are cool, but should be quite rare.

  • souperk@reddthat.com
    link
    fedilink
    arrow-up
    13
    ·
    1 year ago

    this is a method, and always was a method, I just wanted it to look like an attribute for aesthetic reasons

    I think “aesthetic reasons” is an oversimplification. There are certain assumptions a developer makes when reading some code that uses properties. While these assumptions are not clearly defined and may differ per developer, I think there is a common core.

    (1) There are no side-effects. The object is not mutated (or any other object), no IO takes place.

    (2) The time and space complexity is O(1).

    (3) The result is consistent. Consequent calls to the property should return the same value unless there is a mutation between them.

    • VitulusAureus@lemmy.world
      link
      fedilink
      arrow-up
      5
      ·
      1 year ago

      The combination of properties 1 and 3 makes it a pure function, which is also useful in compiled or jittable languages because it allows for a variety of optimizations.

  • souperk@reddthat.com
    link
    fedilink
    arrow-up
    5
    ·
    edit-2
    1 year ago

    (tried to delete this comment but somehow didn’t work, I re-read the article and have a different outlook, sorry for the low effort comment)