• ChickenLadyLovesLife@lemmy.world
    link
    fedilink
    English
    arrow-up
    9
    ·
    edit-2
    2 hours ago

    I started working as a professional programmer in the mid-90s when three-tiered design was all the rage: a data access layer, a business logic layer, and a presentation layer. It seems that nobody actually knew what “business logic” was even supposed to be, because I kept inheriting projects where all the middle tier did was hand data objects from the data layer to the UI. In theory this prevented the UI from being fundamentally bound to the data access, but all three layers were always written in Visual Basic which got kicked to the curb in a few years anyway.

    • bitjunkie@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      edit-2
      3 minutes ago

      My first tech job was writing test harnesses for DCOMs. Your post was a weird trip down memory lane.

    • Buddahriffic@lemmy.world
      link
      fedilink
      arrow-up
      3
      ·
      57 minutes ago

      Business logic would be transformations to the data. Like for a spreadsheet, the data layer would handle the reading/writing of files as well as the storage of each cell’s content. The business logic layer would handle evaluating each of the formulas in the cells, and the presentation layer draws it on the screen.

      I think the part where it gets confusing is that each of these layers are pretty tightly coupled. The end destination of the presentation layer might change, one might show it on a GUI, another might print it, and another might convert it to pdf or html, but each of those presentation layers needs to understand the data that it is presenting, so it’s tightly coupled to the data layer. Same with the businesses logic layer, though it’s tightly coupled on both the input and output sides. The design of the data layer constrains the possibilities of the other two, so it’s hard to draw a clear boundary between the layers because they all need to know how to walk the same data.

      My mental flow chart for this is more of a data layer in the middle instead of business logic, where business logic is to the side with arrows going both ways between it and data layer, then the presentation layer also accessing the data layer directly, which I suppose is a different permutation of what you described.

      Though another way to look at it does make sense. For a website, think of the database as the data layer, the server scripts as the business logic layer, and the client side scripts/html/css as the presentation layer. That one also follows the layered approach where the presentation layer is talking with the business logic layer.

  • addie@feddit.uk
    link
    fedilink
    arrow-up
    12
    arrow-down
    1
    ·
    4 hours ago

    Abstraction is not very compatible with concurrency, so as well as your your beautiful abstract API, you also need some ‘cut through the layers’ functions to return the underlying classes you need to synchronise on. Now you have a right mess that’s incredibly hard to understand, infuriating to debug, and impossible to refactor. Best you can do is put another layer of abstraction on top. Repeat every six months.

    • 3abas@lemmy.world
      link
      fedilink
      arrow-up
      6
      ·
      2 hours ago

      That’s just bad interface… When you design an API as if operations were independent, but they aren’t, you run into these issues.

      Don’t add “cut through the lawyers” functions, fix your interface.

      • Buddahriffic@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        1 hour ago

        Yeah, well-designed abstraction can help enable more concurrency. That said, concurrency isn’t easy at any point once there’s shared data that needs to be written to during the process. Maybe it’s not so bad if your language has good concurrency support (like monitor classes and such that handle most of the locking behind the scenes), but even then, there’s subtle pitfalls that can add rare bugs or crashes to your program.

  • db2@lemmy.world
    link
    fedilink
    arrow-up
    9
    ·
    4 hours ago

    They look so painfully awkward, like a parent should be telling them to knock it off or something.

    • Bosht@lemmy.world
      link
      fedilink
      English
      arrow-up
      5
      ·
      2 hours ago

      If you haven’t seen the vid it’s 500 levels of awkward cringe that’s hard to watch. Had to do with one of the MS version releases. They’re acting so awkward you can’t tell if they’re yakked out in coke or just that socially awkward. Full disclosure I’d be worse than them in that situation, just calling it like it is.

      • Buddahriffic@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        36 minutes ago

        Sometimes tech presentations make me feel really bad for the person giving it. They are up there trying their best but clearly don’t have the skills to do more than just communicate information but still try to make their presentation cool and fun and it just falls flat.

        Anyone can be cool, but not everyone can be cool on demand or on stage.

        Though on the other hand, just because a presenter can pull off the cool factor, it doesn’t mean what they are presenting is actually cool. The coolness of a presentation has no correlation with the coolness of what is being presented, unless that coolness is just information about the product (though even then, they are probably skipping over the flaws and enshitification).

  • Randelung@lemmy.world
    link
    fedilink
    arrow-up
    12
    ·
    5 hours ago

    I recently started a new job. We use Java. There’s a class that does a few things based on explicit arguments only to decide whether to use an FTP or file output, and you supply all parameters yourself. A whole ass Rube Goldberg machine that could be replaced by a single line of Files.writeString.

    Also, there’s a great video on YT “Stop writing classes” that is incredibly relevant.

    • Buddahriffic@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      29 minutes ago

      Yeah, Java’s enforcement of everything must be a class put me off of the language right from the start. I was already used to C++ at that point and hated that I couldn’t just write a quick little test function to check something, it needed a bunch of boilerplate to even get started.

      I still think C++ has a great balance between object oriented and sequential programming. Not sure if it’s the best, but I can’t think of ways to improve on it, other than built in concurrency object stuff (like monitor classes that have built in locks that prevent more than one thread from accessing any of its functions at the same time, basically guaranteeing any code in it has mutual exclusion).

    • Windex007@lemmy.world
      link
      fedilink
      arrow-up
      5
      ·
      3 hours ago

      This hits.

      I stepped into a similar implementation. Took like 6 months and 10 people to support…

      … changing the URL of the sftp server we connected to.

  • WanderingThoughts@europe.pub
    link
    fedilink
    arrow-up
    26
    ·
    7 hours ago

    Just got out of a discussion with a supplier. We can do what we needed by connecting to the database. Instead we have to go through four layers of different tech to arrive at the same point in the database otherwise it’s not compliant. That the supplier needs to sell a license for those layers is purely coincidental.

    • expr@piefed.social
      link
      fedilink
      English
      arrow-up
      8
      ·
      5 hours ago

      Obviously don’t have the full context, but rarely is it ever advisable to give third parties direct access to a database. There are many reasons for this, like, for example, the fact that doing so makes schema migrations practically impossible.

  • red_tomato@lemmy.world
    link
    fedilink
    arrow-up
    62
    ·
    11 hours ago

    Why should I want simplicity? I want to make unnecessarily complex programs to gatekeep those pesky junior programmers.

  • Zannsolo@lemmy.world
    link
    fedilink
    arrow-up
    14
    ·
    edit-2
    9 hours ago

    Me making my devs create a base exception for handling all exceptions that contain messages for display in the UI. Which has a parent base exception we use for all our exceptions which of course has Exception for it’s parent.

    I hate our codebase but I’m so close to killing off 15 year old vb.net code. If the left me alone and I had the time I spent in meetings or 20 mins between meetings everything on our roadmap for the next year would have been done 2 years ago.

      • Logi@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        edit-2
        2 hours ago

        Microsoft conference back in (from memory) nineties with Steve Ballmer (sp?) dancing around stage screaming developers! Developers! Developers! since that’s what market domination is all a outif your are making an operating system.