• Ethan
    link
    fedilink
    8
    edit-2
    1 year ago

    I’ve been working primarily in Go for the past five years, including some extremely complex projects, and I have never once wished I had dependency injection. It has been wonderful. I have used dependency injection - previously I worked on a C# project for years, and that used DI - but I adore Go’s simplicity and I never want to use anything else (except for JS for UI, via Electron or Wails for desktop).

    Edit: If we’re talking about dependency injection in the general sense (separation of concerns, modularization, loose coupling), then yeah I agree that’s kind of critical to writing good, maintainable software. When I hear “dependency injection” I think of frameworks such as Unity, and that is what I was specifically talking about - I am very happy with the fact that I have felt zero need to use any framework like that over the last five years.

    • @[email protected]
      link
      fedilink
      131 year ago

      Go programmer here: What does Go’s simplicity have to do with dependency injection? What does a language itself have to do with dependency injection?

      Reading your post and not being personally familiar with your work, I do wonder, perhaps your “extremely complex projects” wouldn’t be so extremely complex if you practiced dependency injection?

      How do you unit test your extremely complex projects if your business logic carries the additional responsibility of creating objects?

      • Ethan
        link
        fedilink
        2
        edit-2
        1 year ago

        What does Go’s simplicity have to do with dependency injection?

        In my experience, following Go’s philosophy of simple solutions eliminates the need for complex solutions such as dependency injection.

        How do you unit test your extremely complex projects if your business logic carries the additional responsibility of creating objects?

        I write modular code that accepts interfaces so I can test the components I want to test. The vast majority of object creation happens at initialization time, not in the business logic. For the projects I’ve worked on, that would be true with or without DI - I don’t see how that’s relevant.

        perhaps your “extremely complex projects” wouldn’t be so extremely complex if you practiced dependency injection?

        When the CTO says, “Make it distributed and sharded,” I do what I’m told, but that is an intrinsically complex problem. The complexity is in the overall behavior of the system. If you zoom in to the individual execution units, the business logic is relatively simple. But the behavior of the system as a whole is rather complex, and DI isn’t going to change that.

        Edit: I was interpreting “using DI” to mean using a DI framework such as Unity, and I would be happy to never need one of those frameworks ever again.

        • @[email protected]
          link
          fedilink
          31 year ago

          I write modular code that accepts interfaces so I can test the components I want to test.

          basically dependency injection

          • Ethan
            link
            fedilink
            11 year ago

            Maybe I’m misunderstanding what “dependency injection” means. When I hear “dependency injection” I think of a DI framework such as Unity, so I thought “using DI” meant using one of those frameworks.

      • @[email protected]OP
        link
        fedilink
        21 year ago

        I say it’s all about data flow and composability, if it’s pretty much always in one direction (modular tree structure/architecture) then you just don’t need all these “patterns”…

    • @[email protected]OP
      link
      fedilink
      71 year ago

      … until you’ve heard of Rust :)

      (I think Go takes all mediocre language features together and makes an even more mediocre language TBH, take error handling for example, or generic programming (which I agree should be used sparingly, but is super useful if you need it))

      • Ethan
        link
        fedilink
        01 year ago

        I’ve heard of Rust. It sounds noisy and even more verbose than Go, which is already a fairly verbose language. I haven’t had any reason to learn Rust, so I haven’t done so. The error handling is annoying but at this point I don’t really notice it any more. And as interolivary said, Go has generics now.

        • @[email protected]OP
          link
          fedilink
          41 year ago

          Yeah this was my initial reaction way back when I first heard of Rust as well (sometime around 2015 or so I think). TBF it’s definitely not on the same level as e.g. Haskell. But it’s generally I would say less verbose than go (or at least has verboseness where it makes sense compared to go IMHO).

          A good article about this: https://matklad.github.io/2023/01/26/rusts-ugly-syntax.html

          The generic system is also (way) less powerful compared to Rusts (The trait type system/type-classes is really a nice Haskell-inspired thing, that I don’t want to miss anymore). Also the lack of sum types and proper pattern matching makes go more verbose IMHO.

          • Ethan
            link
            fedilink
            21 year ago

            *grumble*. I dabbled in Scala a few years back and I am really grumpy every time I remember that Go doesn’t have sum types, pattern matching, and the closed union of types construction you can create with an abstract final class in Scala. I loved that last one and used the heck out of it. I would love to have a compiler-enforced guarantee that a set of types was closed and could not be extended.

      • Ethan
        link
        fedilink
        21 year ago

        How does dependency injection have anything to do with writing tests? I write tests by writing a test function that executes the code I want to test…

        • @[email protected]
          link
          fedilink
          01 year ago

          I mean unit tests. I work on Spring Boot apps where there are distinct layers (controller -> service -> persistence), and you generally inject mocks into your object to isolate tests to the specific code you want under test. One benefit of this approach is that it’s pretty easy to get 90% coverage.

    • @[email protected]
      link
      fedilink
      21 year ago

      Do you write unit tests with objects mocked via interfaces? Or polymorphism via interfaces? Those are the main reasons to use DI.