• UndercoverUlrikHD@programming.dev
    link
    fedilink
    arrow-up
    124
    arrow-down
    1
    ·
    1 year ago

    Is it really tempting for people? They've given me too many headaches when I've had to reformat or add functionality to files.

    Unless it's a simple single use script that fit on the computer screen, I don't feel like global variables would ever be tempting, unless it's for constants.

    • yiliu@informis.land
      link
      fedilink
      arrow-up
      24
      ·
      1 year ago

      They've given me too many headaches…

      I.e. you did use them, but learned the hard way why you shouldn't.

      Very likely OP is a student, or entry-level programmer, and is avoiding them because they were told to, and just haven't done enough refactoring & debugging or worked on large enough code bases to 'get' it yet.

    • BorgDrone@lemmy.one
      link
      fedilink
      arrow-up
      20
      arrow-down
      1
      ·
      1 year ago

      Is it really tempting for people? They've given me too many headaches when I've had to reformat or add functionality to files.

      I don’t get it either. Why would you ever feel the need for them to begin with?

    • ZILtoid1991@kbin.social
      link
      fedilink
      arrow-up
      3
      arrow-down
      1
      ·
      1 year ago

      Depends on what you're doing. Functional programming has its own downsides, especially once you want to write interactive programs, which often depend on global states. Then you either have to rely on atoms, which defeat the purpose of the functional programming, or pass around the program state, which is janly and can be slow.

      I personally go multi paradigm. Simpler stuffs are almost functional (did not opt for consting everything due to performance issues), GUI stuff is OOP, etc.

    • fluxion@lemmy.world
      link
      fedilink
      English
      arrow-up
      2
      ·
      1 year ago

      As with the sexual connotation here, the temptation is not rooted in long-term considerations like future maintainability

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

      Most people suck at software engineering.

      Plus, there’s always the temptation to do it the shitty way and “fix it later” (which never happens).

      You pay your technical debt. One way or another.

      It’s way worse than any gangster.

    • GTG3000@programming.dev
      link
      fedilink
      Русский
      arrow-up
      1
      ·
      edit-2
      1 year ago

      Well, if you’re writing something the user will be looking at and clicking on, you will probably want to have some sort of state management that is global.

      Or if you’re writing something that seems really simple and it’s own thing at first but then SURPRISE it is part of the system and a bunch of other programmers have incorporated it into their stuff and the business analyst is inquiring if you could make it configurable and also add a bunch of functionality.

      I also had to work with a system where configurations for user space were done as libraries setting global constants. And then we changed it so everything had to be hastily redone so that suddenly every client didn’t have the same config.