Programmers Aren't Productive Anymore - Jonathan Blow

แชร์
ฝัง
  • เผยแพร่เมื่อ 24 ม.ค. 2025

ความคิดเห็น • 727

  • @L1n34r
    @L1n34r 2 ปีที่แล้ว +494

    I feel like his argument is misplaced. It's like saying "back in the day, you could just take a few logs and build a house in one day". Yes, and that house wouldn't have plumbing, electricity, sewer. It wouldn't have good insulation from the outside. The roof would leak a bit when it rains, making it impossible to store certain types of possessions. But hey, you'd have a house in a day.
    And on the flipside, you can still make simple things with simple computers, and people are still doing it. Grab an Arduino, flash it with whatever you want, and you can write your own OS. What's that? Oh, you want more than 64K of space, the processor is slow, and there's limited support for interrupts and no way to play realtime video? Well, welcome to Unix 1.0.
    Standards have changed. Programmers are also less productive, but I feel like he's getting further away from the "why" by looking at requirements. Whole lot of people are chasing the money these days, coming out of two week bootcamps, instead of having an actual passion for writing code.

    • @AbrorkhonN.
      @AbrorkhonN. 2 ปีที่แล้ว +40

      Finally someone with brains

    • @critical_always
      @critical_always 2 ปีที่แล้ว +46

      I would argue it's the modern houses that leak and last nowhere near as long as the old more primitive ones.
      Case in point... I have windows software I wrote 25 years ago. It still runs today. Try that with today's tools.
      Another cracker feature... Real time remote debugging that was 1997

    • @Peter_Lynch
      @Peter_Lynch 2 ปีที่แล้ว +28

      I agree and I think a lot of the "lost productivity" is actually being wasted due to tech companies becoming too big and the bureaucracy associated with it. It literally was the same with mechanical engineering companies before. Some people build a product in a small environment and once it becomes a global success a lot of additional people are needed to simply manage everything (also the technical side) and those people again need new processes with new internal stuff and so on.
      Additionally, a lot of "lost productivity" actually is not lost but being spent on scalability and usability. Simply looking at it from the number of features implemented per employee/time is pretty stupid when Facebook started out with a few thousand users that would post once per day compared to the millions of users and corporations that use Twitter nowadays with multiple messages and videos being posted daily.
      Apps and Websites have evolved a lot in terms of usability the majority of users are not interested anymore in spending hours on grey or black and white forum web pages that only support text with a terrible search function.
      Comparing the pure functionality of some mercedes a decade after it was invented to one now is basically the same. Both cars drive and get you somewhere but the comfort/usability of the two products are something completely different.

    • @ahdog8
      @ahdog8 2 ปีที่แล้ว +17

      I mostly agree. But I'm a bit skeptical about the last point as well. Programmers may not be losing that much productivity at all. The charts that were shown in the video were labelled "number of employees" not "number of engineers." Maybe that includes help desk people and marketers and whatever.
      If someone has more convincing statistics, I would take a look.

    • @Peter_Lynch
      @Peter_Lynch 2 ปีที่แล้ว +3

      @@ahdog8 It surely does include all of those as well.

  • @codingrules
    @codingrules 2 ปีที่แล้ว +454

    All good causes that he lists, but the biggest cause is the much higher demands on software today.
    I'm a third generation software developer and have talked with my dad and granddad about these things. Back in the day most programs were simple. Now you need a sophisticated and user-friendly GUI, Server/client or peer-2-peer communication over some protocol, complex databases, security, scalability, metric collection, statistics presentation, sophisticated rollback, integrations with all kinds of third-party systems. Plus a sea of technologies/frameworks/libraries/tools to get anything done because building your own XML-parser from scratch is stupid, but now you have to master all these things, where before you simply didn't need any sophisticated parser. Also as technology has allowed it more and more legislation and bureaucracy imposed by the state has effected the processes around software-development and even worse the software itself (GDPR for example). To all this add that users often demand more advanced features today (it was very basic what the software my dad made in the 80's had to do).
    Further more there are more bad software-developers. Many think being a developer is about writing code (as in you just need to know one or more programming languages in depth). It is correct that you write code, but think of it as articulating solutions so to speak (like when you make a mathematical proof and articulate it in a mathematical notation), but what is hard is recognizing the problems and conceive the solutions (like math). And you can't think of a solution and make somebody else code it because coding and crushing problems happen in tandem. Also, passing a complete solution to another human being would be the same as writing the code yourself.

    • @82NeXus
      @82NeXus ปีที่แล้ว +19

      I think that's half right. Developers just have more features to develop these days. But if all those features were useful and worthwhile then you could say that developer productivity was as high or higher than it used to be! The problem is in a lot of software, even a lot of games, but I'm more thinking of other software, only some of the modern features are useful and a lot of them are just pointless. Often people work hard at producing stuff that doesn't even need to exist, either by being misguided or not very bright, or deliberately, for money! Or spend time learning and using complex tools and processes where something simpler would work better.

    • @Muskar2
      @Muskar2 ปีที่แล้ว +30

      The "sea of technologies/frameworks/libraries/tools to get anything done" is likely a main reason productivity is slow in the long-term. They give you a quick and dirty solution for prototypes but they make maintainability a pain and instead of learning what your code is actually doing, you're spending time learning arbitrary made-up pipelines and functions, trying to dig up what the black box libraries actually do under the hood - and when they're actually open source you find out that they're impossibly complex and will take a very long time to understand. But it doesn't have to be that way. It's because of modern software dogma of turning everything into modules, singular generalized objects and overreaching pipelines.

    • @stuart6478
      @stuart6478 ปีที่แล้ว +3

      long story short, you can fix something until it breaks. why I have zero faith in tech long term. ha ha suckers

    • @sepg5084
      @sepg5084 ปีที่แล้ว

      ​@@stuart6478you have zero faith in tech, yet you are using it daily? You have faith in it then 😉

    • @Zevonthethompsongun
      @Zevonthethompsongun ปีที่แล้ว +1

      "need" is an interesting choice of word here.

  • @rubberduck2078
    @rubberduck2078 2 ปีที่แล้ว +365

    The big elephant in the room is that nowadays even if you program in assembly you still don't know what the CPU is doing with all the register aliasing, speculative execution, muop fusion, out-of-order execution etc

    • @BrunodeSouzaLino
      @BrunodeSouzaLino 2 ปีที่แล้ว +51

      This was one of the contention points when a bunch of VHDL files on AMD cpus was leaked on the internet. The amount of people which understand hardware at component level like that wouldn't even have interest in those. They're already employed in well paid positions, as hardware designers are a very finite number of professionals these days. The dellusion that you know hardware at component level is very high amongst older programmers simply because they know lower level languages.

    • @lucemiserlohn
      @lucemiserlohn 2 ปีที่แล้ว +36

      @@BrunodeSouzaLino Well, they also know old systems where that assumption, knowing what the machine did at the lowest level, held true. And we see the consequences of people losing this ability every day - that why we get stuff like electron or similarly bloated stuff that requires hundreds of megabytes in memory and assets to do the simplest thing possible. And the fact that people seem to be okay with that and just shrug it off like nothing.

    • @BrunodeSouzaLino
      @BrunodeSouzaLino 2 ปีที่แล้ว +8

      @@lucemiserlohn There's two things Electron is good at:
      - Cross platform apps
      - Developing time
      Writing and maintaining cross platform native apps requires a lot of time and effort and it's an uphill battle with systems like Linux distros, where it is impossible to cater to every single case or set of apps each user has installed.

    • @lucemiserlohn
      @lucemiserlohn 2 ปีที่แล้ว +16

      @@BrunodeSouzaLino I never said electron is not useful in certain cases; it's just bloated and painfully slow, both aspects which I personally do not want to deal with, neither on the developer side nor the user side.

    • @LC-hd5dc
      @LC-hd5dc 2 ปีที่แล้ว +9

      there's a good usenix talk on this subject and OSDI, specifically that the "operating system" barely has any control over most of the hardware. most of the hardware communication happens via ad-hoc black-box firmwares written by who-knows-what company, with absolutely no cache coherence compared to the OS

  • @ed7590
    @ed7590 2 ปีที่แล้ว +435

    I don't agree that abstraction is to increase productivity at all, abstraction allows you to increase the complexity of a system. You can now package ideas and interface with them in a way that is human friendly meaning your brain can keep track of a lot of interacting components.

    • @LC-hd5dc
      @LC-hd5dc 2 ปีที่แล้ว +55

      the limitations also exist for a reason. you do not want a bug in a program to wipe your disk or fry your cpu for example

    • @MrHaggyy
      @MrHaggyy 2 ปีที่แล้ว +23

      hiding complexity in for example interfaces is increasing productivity. I don`t think the number of components programmers keep track of has changed. It`s just that instead of pointers and a list addresses in ram we use containers, instead of writing 10th thousand lines of code we use for example network stacks. The level of components we use implements a very abstract function for us so within the limits of our brain we can design ever-enlarging systems.

    • @steffenpanning2776
      @steffenpanning2776 2 ปีที่แล้ว +5

      statically linking opens another can of worms. You need to keep track of the security issues of the libraries you use. If you use a dynamically linked library and that library has a bug, you replace the library.
      If the programs are statically linked, you have to keep track of the libraries that each program uses, then you have to recompile all affected programs and redistribute them.
      Secondly the admin can't even tell anymore which programs are vulnerable and must rely on the diligence of the programmer.
      He has to check if any of the programs he wrote in the past uses a vulnerable library, recompile it and redistribute it.

    • @MrGerdbrecht
      @MrGerdbrecht 2 ปีที่แล้ว +4

      Complexity is the source of most problems. I use templates in C++ not to introduce more complexity, but flexibility. You have to very careful about that abstraction most likely increases your distance from the actual problem u wanted to solve in the first place. And regarding speed the optimized version is most likely a very specific solution and not a general one.

    • @serbrighterunagainst9231
      @serbrighterunagainst9231 2 ปีที่แล้ว +6

      @@LC-hd5dc A bug to fry the cpu... wow

  • @edbrito-swdev
    @edbrito-swdev 2 ปีที่แล้ว +462

    This has a "old man yelling at clouds" kind of vibe to it.

    • @BittermanAndy
      @BittermanAndy ปีที่แล้ว +12

      Yup. This is if one of the Four Yorkshiremen was allowed to give a TED talk.

    • @JeremyHelm
      @JeremyHelm ปีที่แล้ว +2

      What are the relative years of experience here? Perspective?

    • @Raxfyr
      @Raxfyr ปีที่แล้ว +62

      this is Blow's whole vibe now. he programs all his games from scratch, even going so far as to write his own language. there is nothing in his games that remotely require that. he is the epitome of thinking he's the smartest one in the room

    • @JackMott
      @JackMott ปีที่แล้ว +18

      he has turned into a gross boomer just like Elon, and it is tragic as both had so much to offer. and i say that as a fellow old programmer

    • @pretzelboi64
      @pretzelboi64 ปีที่แล้ว

      @@Raxfyr He's just what a painter is to digital art but for programming instead. Like, not everyone needs to be smashing prompts into a generative model or using digital painting software. Hand-painted artwork is still in demand and so are handcrafted games. It's not because you don't appreciate something that nobody else does. Get your head out of your ass a little

  • @ybergik
    @ybergik 2 ปีที่แล้ว +541

    I can't believe he didn't comment on the key thing Ken hintet at that allowed him to write the first unix kernel: Being left the F alone! Teams ruin productivity and creativity. The bigger teams, the less productivity. The tools we are handed are generally cripled with a hateful OS - and add to that all the crappy antivirus, "group policies", lack of admin rights, firewalls blocking you from downloading standard programmer tools, SDKs, etc. - all things that are actively slowing you down (or outright preventing you from doing your work which you then need to spend a lot of time circumventing.)

    • @Akeruyri
      @Akeruyri 2 ปีที่แล้ว +24

      With teams you end up with a larger range of project scale that can be produced, but at the same time you end up giving each person on the team less stuff to do overall, ruining their productivity.

    • @La0bouchere
      @La0bouchere 2 ปีที่แล้ว +96

      Yeah, everyone in management needs to read Deep Work. The amount of consecutive hours you can work with no distractions is the largest factor in someone's productivity, and most companies won't even let you ignore slack for 15 minutes.

    • @higgins007
      @higgins007 ปีที่แล้ว +9

      @@La0bouchere Someone pin this comment.

    • @zyriab5797
      @zyriab5797 ปีที่แล้ว +36

      Someone please abolish standup meetings, retros and estimation sessions 😥

    • @stuart6478
      @stuart6478 ปีที่แล้ว +1

      it's almost like entropy exists

  • @IanMcGowan
    @IanMcGowan ปีที่แล้ว +69

    It's a mistake to divide the "new features" at Facebook by the number of programmers at Facebook - most of what they are doing is not producing features that benefit users, but rather features that make Facebook more money, which are not visible to users (on purpose).

    • @AlFasGD
      @AlFasGD 11 หลายเดือนก่อน

      So you're saying that most of them are data pseudo-analysts/pseudo-engineers?

    • @amotriuc
      @amotriuc 11 หลายเดือนก่อน +4

      As well he did a mistake somehow thinking that first Unix made in 3 weeks was sign of productivity. The complexity of that Unix was so low, modern programmers would have probably finish it in 1 week I suspect.

    • @stoomkracht
      @stoomkracht 11 หลายเดือนก่อน

      @@amotriuc Only when they can dump in a dozen heavy frameworks to do the actual job.

  • @PatternShift
    @PatternShift 11 หลายเดือนก่อน +10

    "I know what we need to do to get back to the days where we could write an operating system in 7 days!" says the guy who takes 7+ years to deliver each game.

    • @infinitelink
      @infinitelink 9 หลายเดือนก่อน +2

      That becomes a big hit.Often for the year. With sales in the tens of millions. for puzzle games. That are built by a small team not an immense AAA studio. As craft and not a template. That works when released rather than getting released expecting to bring it to a working state with updates and patching via the internet...

    • @Khwerz
      @Khwerz 8 หลายเดือนก่อน

      Exactly, he has to port to each os which probably takes a lot longer. He also doesn't use unreal engine, he's not building yet another fps.

  • @womp6338
    @womp6338 ปีที่แล้ว +118

    I’m a senior engineer at a large tech company and most days all we do is circlejerk about patterns and refactoring code and never deliver anything. Everything is hilariously over complicated to the point where extremely basic stuff takes weeks to do.

    • @ChaoticTrack
      @ChaoticTrack ปีที่แล้ว +10

      Using the right abstractions should make basic things take less time, not more... no? I was in a similar situation (debating approaches eating up time), but I think "patterns/refactoring bad" is a red herring.
      For us, features took a long time in part because the code was fragile, full of cycles, and so inconsistent it might be considered abstract art. :P
      A more fundamental problem was that no one on the team (including me) had the expertise to say, "I've done something like this before, here's what I've seen go wrong ... I recommend approach X for reasons Y and Z," so that we could just get to it. That's how I learned expertise means a lot more than job titles; if no one has done the reps, we're always in uncharted territory. It also takes trust for that to work, and trust is earned.
      If we _didn't_ spend time on design, new code was fragile, hard to read, hard to debug, and exacerbated tech debt. If we _did_ spend time on design, it would take weeks to get to something that was _ok_, but it would have taken even longer to get to the 'right' (sustainable) solution.
      We didn't have any underlying goals/non-functional requirements to justify which refactorings were worth the time (e.g., "component X must be fault tolerant because it's the foundation for mission critical functionality Y", or "components A through F run

    • @ЏонМастерман
      @ЏонМастерман 11 หลายเดือนก่อน +5

      Damn bro, you must be at Cisco

    • @womp6338
      @womp6338 11 หลายเดือนก่อน

      @@ЏонМастерман it's a company that has a monopoly over data centres in the country I live. They don't have to try.

    • @master74200
      @master74200 11 หลายเดือนก่อน +3

      That sounds like an absolutely awful company to work for

    • @curtisw0234
      @curtisw0234 11 หลายเดือนก่อน +4

      Just one more abstraction bro, it will abstract away all the other bad ones, bro plz just one more

  • @Mr30friends
    @Mr30friends 2 ปีที่แล้ว +124

    How is using one specific genius like Ken Thomson who worked at the most state of the art computer R&D lab at the time, a valid example to describe a whole generation of programmers.
    Its like saying that people in the 1900s were the smartest generation ever because Albert Einstein published his relativity theory at that decade. Makes no sense.

    • @LCTesla
      @LCTesla ปีที่แล้ว +14

      also it's ridiculous to imply that the world would be more productive if every programmer produced a new operating system every 3 weeks.
      we already have too many of the infernal things and this was something he himself was complaining about in this talk.

    • @skycaptain95
      @skycaptain95 ปีที่แล้ว

      Einstein was a thief

    • @HansBezemer
      @HansBezemer 11 หลายเดือนก่อน +1

      The guy wrote a small regex engine with a handful of lines of code. The guy can write a program, trust me.

  • @Weeman2541
    @Weeman2541 2 ปีที่แล้ว +198

    After messing around in TempleOS out of interest I do get where Jonathan is coming from.

    • @chillappreciator885
      @chillappreciator885 2 ปีที่แล้ว +5

      Did Oracle App tell you that?

    • @NicholasStabile
      @NicholasStabile 2 ปีที่แล้ว +26

      Helps both of them are of the same generation (Terry Davis and Jonathan Blow), they are really productive people.
      I remember Terry Davis multiple rants regarding the English or Humanity people getting involved in programming and often doing things that are affront to computers and talked about how important it is to program the way the computer wants it to be done.

    • @tx7300
      @tx7300 2 ปีที่แล้ว +23

      @@NicholasStabile you mean the way God wants it to be done

    • @Fru1tpunch
      @Fru1tpunch ปีที่แล้ว +1

      @@NicholasStabile what stream is that

    • @LionKimbro
      @LionKimbro 11 หลายเดือนก่อน

      @@tx7300But that goes without saying- they are the same thing.

  • @Peter_Lynch
    @Peter_Lynch 2 ปีที่แล้ว +116

    I think a lot of the "lost productivity" is actually being wasted due to tech companies becoming too big and the bureaucracy associated with it. It literally was the same with mechanical engineering companies before. Some people build a product in a small environment and once it becomes a global success a lot of additional people are needed to simply manage everything (also the technical side) and those people again need new processes with new internal stuff and so on.
    Additionally, a lot of "lost productivity" actually is not lost but being spent on scalability and usability. Simply looking at it from the number of features implemented per employee/time is pretty stupid when Facebook started out with a few thousand users that would post once per day compared to the millions of users and corporations that use Twitter nowadays with multiple messages and videos being posted daily.
    Apps and Websites have evolved a lot in terms of usability the majority of users are not interested anymore in spending hours on grey or black and white forum web pages that only support text with a terrible search function.
    Comparing the pure functionality of some Mercedes a decade after it was invented to one now is basically the same. Both cars drive and get you somewhere but the comfort/usability of the two products are something completely different.

    • @RegiJatekokMagazin
      @RegiJatekokMagazin 2 ปีที่แล้ว +1

      the car thing is not really comparable i think, its just an old invention what got to business and drives humanity so badly, destroys earth ecosystem,, 4 wheels do the same over a century, the software things are really stupid to think about, i think its just a good hobby or a thing what you are exited about and goo to deal with it, its like music, should not be taken this complex anyway
      the real jobs are about survival and material things, building house, agriculture, but after all everything is being with a problem too, you cant except from the nature what you want exactly, somewhere, something, going to crash and you have to solve it somehow, or leave it and go on to the next thing

    • @Peter_Lynch
      @Peter_Lynch 2 ปีที่แล้ว +1

      @@RegiJatekokMagazin I really don't get any of your points :D

    • @RegiJatekokMagazin
      @RegiJatekokMagazin 2 ปีที่แล้ว

      @@Peter_Lynch I want more information about that, why you didnt get it, so we can make a point :)

    • @stuart6478
      @stuart6478 ปีที่แล้ว +2

      someone is working on their excuse to keep their job.

    • @kerrinnaude2777
      @kerrinnaude2777 ปีที่แล้ว

      Sir do you know of the Longhouse? If not some there are some great articles, namely (google) "What is the Longhouse?" - for the more cultural take that goes hand in hand with what you said.

  • @gettem6341
    @gettem6341 2 ปีที่แล้ว +17

    0:54 "That's how people are wrong a lot of the times, you start out being right, then you extrapolate it too far into wrong territory"

  • @sefirotsama
    @sefirotsama 2 ปีที่แล้ว +28

    some whacky arguments being done here, large companies are eaten by bureaucracy, maintenance and very specially: communication among them. People and teams don't scale. Large companies and products try to avoid feature creep as it adds more maintenance, and collides with previous existing features and structures.

    • @THEROOT1111
      @THEROOT1111 11 หลายเดือนก่อน

      Exactly.

  • @sjatkins
    @sjatkins 2 ปีที่แล้ว +79

    Today to be "full stack" you have to be 50% of a dev ops engineer in many an organization, especially in start ups and small-ish companies. That greatly interferes with software development productivity. Also too often today a large percentage of your job as software developer is to manage the use of up to a dozen SaaS packages that the CTO decided would "save effort and cost" each with their own peculiar merits, demerits, behavior as APIs and whatever the heck was in the heads of their devs. Banging on these to make it more or less satisfy business requirements dependably and with reasonable performance is a full-time job often. That leaves little time to write or think of writing the actual software that would most efficiently meet the business needs.

    • @honkhonk8009
      @honkhonk8009 ปีที่แล้ว

      Fuck that shit honestly.
      Tryna save time and money by "saving software" is pure fucking folly. Especially with AI's these days.
      Everything is gonna need to be rewritten fully. Thats just unavoidable. Its less painfull though cus we got fucking AI.
      Its so braindead tryna modularize code and all, only for it to not even remotely matter cus of how much work u gotta put in to integrate it.

  • @unduloid
    @unduloid ปีที่แล้ว +99

    The reason programmers are "afraid of pointers" is that raw pointer arithmetic leads to a massive amount of bugs, in turn leading to applications in production going haywire in de most unpredictable ways. Also, programmers to do low-level programming well they need lots of time to concentrate at the issues at hand ... which is pretty much an impossibility in this day and age of DevOps and Agile.

    • @sacredgeometry
      @sacredgeometry ปีที่แล้ว +2

      On big systems and when working with other people ... absolutely. In general. Absolutely not.

    • @pretzelboi64
      @pretzelboi64 ปีที่แล้ว +14

      You don't even need to do pointer arithmetic yourself anymore. It's all handled by array indexing but people are still afraid of a fucking value holding a simple RAM address

    • @udirt
      @udirt ปีที่แล้ว +3

      The lot of time part echoes with me as a sysadmin - in my field productivity is also strongly linked to idle times. Since you're all-times split between daytoday and readiness to deal with outages and projects you need to spread buffers everywhere where your colleagues and you work on keeping their edge over the needs of the day to day.
      If you spend all time in agile standups, 1on1s or chasing your sprints fixing bugs you'll not be able to have that edge. Not be able to gain the distance from your current detail issue takes away the chance to coordinate with colleagues, and to idly spin ideas.

    • @antonhelsgaun
      @antonhelsgaun ปีที่แล้ว +4

      ​@@pretzelboi64it's not really a ram address, but yeah

    • @captainfordo1
      @captainfordo1 ปีที่แล้ว +8

      Sounds like a skill issue. But in all seriousness, this is just an easy copout. “Oh it’s too hard, oh I’ll make too many mistakes.” You’ll make mistakes regardless of if you use a low-level language or not, and especially if you don’t practice. By practicing using pointers, you’ll better understand how they work and eventually avoid making mistakes entirely. There’s also numerous memory management strategies, such as arenas, that simplify dynamic memory allocation quite a bit. Pointers are really not scary at all.

  • @phantomapprentice6749
    @phantomapprentice6749 2 ปีที่แล้ว +14

    3:43 The problem with example is that actually a lot of innovation within these big corporations gets shot down, And I say that because I know people who work or have worked at these kind of companies. Usually its either because of inner-corporate politics or because people think its not good enough, so saying that you don't see the productivity as an end user, doesn't mean devs are not being productive, they just cater to the whims of executives or seniors who don't appreciate that productivity or are too conservative and ultimately reject it.

    • @adammiller9029
      @adammiller9029 11 หลายเดือนก่อน

      No. The problem is people fantasize about big corporations wanting innovation or even needing innovation. They don't. Most organizations want you to competently make an API call between their accounting system and their time card system. They want you to glue disparate systems together so that their business functions in a cohesive way. Showing an example of a grade computer science pioneer genius writing an operating system at Bell Labs, whose only goal, with to spend as much money as fast as possible on R&D to average developer applying critical thought on solving a normal business problem, makes this man look like king of the shmucks. He is Shmuck Man, comparing of things that don't make sense. If you're being paid to say.... develop a time keeping system and instead built an OS, you'd be fired. Because you don't work in the whimsical word of Bell Labs where every developer has full autonomy and an endless budget that doesn't need justified and you don't even need a relevant business problem to solve. You can just "Do Stuff". In the real world, with real businesses not in 1980, businesses have narrowly defined problems they need solved. They need some one to randomly poop out an operating system for funzies.

  • @bitwize
    @bitwize 2 ปีที่แล้ว +56

    Lisp is one of the most abstract languages around. At Symbolics, a company that sold Lisp-based hardware and software solutions, a VP once claimed their ambition was to make all but the largest of software projects achievable by a single developer. (Small teams would tackle the largest projects.) And it looked like they would be abke to do that. Small teams built Genera, the Lisp OS, their document management system, their expert system solver, and their suite of 2D/3D graphics tools that were the rival of anything produced by Pixar at the time.
    But large companies like large teams -- to a middle manager, a large team means a large budget and a large subordinate count they get to command -- and so as the capabilities of small teams grow, that extra productivity is taken away by the introduction of processes and methodologies designed to slow small teams down and necessitate large teams with large management infrastructures.

    • @tengamangapiu
      @tengamangapiu ปีที่แล้ว

      Incredible that so many things came out by using Lisp. I remember learning it in college and the recursion was hard to grasp, but the mental models created helped so much in the long run.
      One of the projects was creating a SQL like interpreter, using some helper library. I think our team finished it in a weekend.

    • @warmwaffles
      @warmwaffles ปีที่แล้ว +6

      Large companies like large teams because people quit. If one or two devs quit on a large project, it's okay. All knowledge is not lost, but if one or two devs quit from a small team, you lose a ton of knowledge that can not be regained without dedication.

    • @thefakewitchdoctor
      @thefakewitchdoctor ปีที่แล้ว +1

      Managers also like large teams as it makes their resumes look good.

    • @alexisfrjp
      @alexisfrjp ปีที่แล้ว +1

      They try to achieve the same in the FPGA world with HLS...
      Promise? no need of hardware and low-level knowledge anymore. Good luck.

  • @woodmanmade
    @woodmanmade ปีที่แล้ว +4

    Gotta love a Jonny Blow take; big claims with no evidence but a lot of confidence

    • @asandax6
      @asandax6 ปีที่แล้ว

      You can literally use almost any modern software as example.

  • @JeremyCaron
    @JeremyCaron 2 ปีที่แล้ว +40

    This talk is hot garbage. Developer productivity is not approaching zero, and places where it is, it's usually the fault of crappy management, not the choice of a higher level language than assembly....

    • @vamastah1737
      @vamastah1737 ปีที่แล้ว +4

      He is not blaming developers, at least I do not see it as blaming. He just states the fact that effectively most developers write almost no code. That's why I do not work as a programmer anymore - too many meetings, too much unproductive talking, no programming assignments. If you like coding, do not aim to be a corporate developer.

  • @Muaahaa
    @Muaahaa 2 ปีที่แล้ว +55

    The metaphor of measure productivity as just new features for productions (like Twitter and Facebook) is incorrect, or at least very incomplete. It is only one axis. You can take a product and change no external features, but go from 1000 daily users to millions. In order to support that you need a lot of different things to happen. There are ports to other platforms, internationalization and so on.
    I think there is also a point to be made about constant feature changes not actually being super desirable, especially as a product grows. The more users there are invested in how a product works, the more care it takes to change that product. The more tools and infrastructure you tend to have to support the evaluation and safe deployment of feature changes. And because of the scale of the user base, a small feature change that affects millions is probably "more productive" from a business perspective than many feature changes that affect only thousands of users.

    • @alexisfrjp
      @alexisfrjp ปีที่แล้ว +1

      Port to other platforms and internationalization isn't development per se, it isn't creation of something.
      Yes your house needs some fixes here and there but you don't need to rebuild the whole house every time with architects and engineers involved.

    • @Maronicam
      @Maronicam ปีที่แล้ว +5

      @@alexisfrjp If Your house was fit for 5 people and now needs to house 5 million... You need more than making the kitchen a 1 mil times bigger.

  • @ChristopherDrum
    @ChristopherDrum ปีที่แล้ว +11

    There is one thing we should keep in mind with the comparison of "number of developers employed" vs. "tangible developer efforts" at the big tech companies. They aren't necessarily hiring for productivity, I think. That hiring is, at least in part, driven by the need for infinite growth. They have to show that they're always growing to "make line go up." Later, they'll prune the developers they didn't actually need in the first place to show "fiscal responsibility" which will "make line go up." Still later, they'll overhire to "make line go up" again, etc.

  • @georgeoreilly1546
    @georgeoreilly1546 2 ปีที่แล้ว +53

    The majority of software and features that is built is never used. Just requests by managers, then when the software or features is ready 3 months later, those managers are onto something else, the business case for the software doesn't make sense etc. There are about 2.7 million apps for android, about 1.000 apps per day. Yeah right.

    • @rishatsharafiev
      @rishatsharafiev 2 ปีที่แล้ว +9

      Yes, managers need to explain to C-level why they get salary, so they generate features like crazies. Their approach is usually quantity over quality

    • @yalslaus
      @yalslaus 2 ปีที่แล้ว +6

      It's quite common these days in all industries. Make new product with barely any need , product managers exaggerate what market wants or where market is headed just so you can sell something new. Re-inventing of the coke bottle but with software. Maybe its different at the top tech companies but a majority of software engineering seems to fall under this.

    • @LC-hd5dc
      @LC-hd5dc 2 ปีที่แล้ว +1

      @@yalslaus the "top" tech companies are worse because they have a dozen teams all duplicating work because they've ended up not communicating with each other

  • @9SMTM6
    @9SMTM6 2 ปีที่แล้ว +50

    The reason people were able to just create an OS in a few days is there were no standards.
    You complain that there's a shitton of different Shader languages? Besides vendor lock-in, which will likely attribute for some of it, the reason is that people went at it with your perspective. Why spend time trying to establish a standard, when we can just make stuff up ourselfes.
    The reason OS's complicate deploying Programms is because they allow one to use more than one program at the same time, and that requires coordination of shared resources.
    Yeah, if you'd write it from ground up PERHAPS (depending on what you're doing, probably not most of the time) you'd be quicker, but you won't be able to run that while also browsing on the same machine, and every program would have its own idiosyncraties that users would have to get used to.

    • @rasputozen
      @rasputozen 2 ปีที่แล้ว +2

      The dunning-kruger effect strikes again.

  • @shaurz
    @shaurz 2 ปีที่แล้ว +138

    The big tech companies of today are in a real mythical man month situation. Move any small piece of their humongous code base and something breaks. Even with thousands of the best engineers can't make much progress, adding more leads to diminishing returns. The best thing for the economy would be for big tech to go bust and release these engineers back in to circulation where they can create new, better software from scratch.

    • @RogerBarraud
      @RogerBarraud 2 ปีที่แล้ว

      Nope. The most valuable service the Big Tech companies provide is keeping those n00bs away from the rest of us.
      FANG-employment-seeking is a disease, fortunately they are self-isolating.

    • @piffe
      @piffe 2 ปีที่แล้ว +12

      Do you work in a top ten tech company and have evidence of this? I do and this is most definitely not the case where I’m at.

    • @rdean150
      @rdean150 ปีที่แล้ว +9

      Need to move to containerized microservices and CI/CD pipelines. Monolith codebases of intertwined dependencies are out, self-contained packages running in containers and communicating via messages is in. The development process has more overhead, storage/memory usage is much higher, and constant environment setup is a pain in the ass, but it solves the vastly bigger problem of fragile, interdependent monolith systems.

    • @shyshka_
      @shyshka_ ปีที่แล้ว

      you have zero clue what you're talking about lol, are you even in the industry?

    • @stuart6478
      @stuart6478 ปีที่แล้ว +5

      frankly it should just fall apart for the good of the world.

  • @bike4aday
    @bike4aday 2 ปีที่แล้ว +21

    One reason for the lack of compatibility is that companies do it on purpose to compete with each other. They make their stuff unique so it's harder to move to someone else. They create a big support team and restrict third parties from providing support. Having full control over their product and not having to worry about conforming, they can optimize the user experience.
    Of course when considering the bigger picture, these reasons have immense drawbacks and do not benefit the industry as a whole or the users.
    "One who only cares about their own wellbeing can't possibly contribute to overall wellbeing."

  • @WizardofWestmarch
    @WizardofWestmarch 2 ปีที่แล้ว +15

    While I get where he's coming from and agree with a fair bit of it, the company thing isn't entirely tech issues (not that the amount is zero). Software red tape in business seems to get worse by the year. I'm a fairly important developer at my work and yet there are more than a few weeks I spend more hours in meetings than I do getting to actually code. I wouldn't be surprised if FB/etc have the same problem.

  • @miikavihersaari3104
    @miikavihersaari3104 2 ปีที่แล้ว +168

    You can't just enjoy programming and command the machine. You must go through an API provided by a corporation.

    • @thewiirocks
      @thewiirocks 2 ปีที่แล้ว +29

      The API is fine. It’s that developers today struggle to use them. Once upon a time, APIs were a great way for software engineers to communicate and share with each other. Today, it’s a skill unto itself that requires a 2 week training course. WHY?!? Can’t we just read the documentation and try it out? If it doesn’t work for us, don’t use it. But in practice, we first invest in a multi-week training course, then claim certification on “the thing” and then we have to use “the thing” because we’ve invested so much sunk cost into it. That’s bananas!

    • @miikavihersaari3104
      @miikavihersaari3104 2 ปีที่แล้ว +30

      @@thewiirocks Many corporate APIs have restrictive aspects to them that are not there to solve or aid in solving an engineering problem, but instead to give a business leverage. In cases where you have no other option but to go through an API you are at the mercy of the author of the API, and if it doesn't expose what you need you've now got an artificial problem on your hands that adds an unnecessary complication/hindrance to your work.

    • @kleozane2781
      @kleozane2781 2 ปีที่แล้ว +4

      @@thewiirocks The reason why a lot of software companies fail, they overextend everything

    • @thewiirocks
      @thewiirocks 2 ปีที่แล้ว +12

      @@kleozane2781 Software companies fail for the same reasons that all companies fail. They are unable to provide a product desirable to the market at a price that is acceptable. Everything else is just noise and may or may not contribute to the failure of any one company.

    • @kleozane2781
      @kleozane2781 2 ปีที่แล้ว +7

      @@thewiirocks Another point is outsorcing everything. The company I used to work at had this problem, they tried to outsorce everything.

  • @brianmccullough2420
    @brianmccullough2420 2 ปีที่แล้ว +18

    Having just an undergraduate degree in Electrical engineering I understand what he was talking about, but have three fundamental critiques.
    1. He just states that the productivity of programmers is approaching zero and then doesn’t really justify the claim besides his twitter graph and a single anecdote from one bell labs engineer from the 60’s who probably wrote code that others had to meticulously parse through later for all the bugs.
    2. Just because Twitter isn’t adding functions doesn’t mean its programmers are less productive. Every corporation has diminishing marginal returns as its workforce grows and software companies are no exception. Programmers could be working on a whole host of other things including maintenance, security, scaling, and testing.
    3. All professions these days are highly specialized, yes it would be good for all programmers to know all languages and levels of abstraction, but it’s absurd to expect the majority of programmers to learn all of this if they only need to know the key technical literature and 2-3 languages really well to be productive at their job.

    • @LC-hd5dc
      @LC-hd5dc 2 ปีที่แล้ว +3

      the real kicker is that even the OS doesn't have true hardware access. also the metric of "features per programmer" is the funniest metric i've heard of

    • @Drcardenas
      @Drcardenas 2 ปีที่แล้ว +4

      Right!? Also, one of the main reasons civilization even exists in the first place is due to specialization of work. Now we're using that as a metric for the decline of civilization? I'm sorry. I'm not buying it after two measly graphs and one short video.

  • @T1Oracle
    @T1Oracle ปีที่แล้ว +6

    This is absurd. I can launch a cross platform website that works on multiple OS's including mobile devices and desktops, in a weekend, without having to build my own web browser.

    • @friendlyfella123
      @friendlyfella123 ปีที่แล้ว +1

      exactly, this guy is obsessed with a perverted interpretation of productivity and he's built quite a cult following around it too

  • @voidborn-one
    @voidborn-one 2 ปีที่แล้ว +32

    Some time ago, you could slap a few lines of code and publish it freely, even by newspaper and post. Now even before you publish your first MVP there has to be a licence, a strategy for GDPR, you need to make sure it is compliant with law and probably you also need to follow guidelines from publisher (like Google Play). On top, how much you integrate with other APIs like identity providers, payment processors etc the more chance is you will remove friction that lose users. So much boilerplate on top of value

    • @SC1240
      @SC1240 2 ปีที่แล้ว +3

      don't forget running the PR through 3 cycles of pointless revisions

    • @honkhonk8009
      @honkhonk8009 ปีที่แล้ว

      Thats what happens when you let communists run shit.
      They have no concept of an ideal world without incessant state controll.

  • @cbbcbb6803
    @cbbcbb6803 2 ปีที่แล้ว +36

    I remember reading about a guy that when ever he created a user application he wrote an operating system to go along with it.
    Now, everything has too many parts just to have parts.

    • @shableep
      @shableep 2 ปีที่แล้ว +8

      Here’s the thing. Imagine you want to make a fun puzzle game for a phone. Imagine how daunting it would be if step 1 was “write an operating system”. This is a wildly oversimplified understand of the systems we’re working on. Imagine you start a game on your phone with its own operating system. Your computer shuts down, and then boots you the game. Ok, let’s pause the game and check my email. Oh wait- hold on. I have to shut down my phone and boot up my email operating system.
      Abstraction is being able to use the efforts and expertise of others to enhance your work. Leave the OS engineering to the OS engineers.
      When you build a house, there are people that build the foundation, people that build the framing, people that put up the dry walls, and people that put on the roof. One person can do all of these things, but it’s much quicker for people that are specialized in specific things that do it every day to do that specific thing.

    • @rasputozen
      @rasputozen 2 ปีที่แล้ว +6

      @@shableep It's quicker to delegate the labor to specialists but it results in a worse product. The best homes are built by one or a few people with a common vision and an understanding of ALL the systems involved. The reason software expires pretty much on arrival today is because of years and years of delegation compounded on top of each other. No single vision. Design by committee. Disposable garbage.

    • @higgins007
      @higgins007 ปีที่แล้ว

      Basically how all Amiga games worked. It was very rare for a game to require Workbench. You just put the game disc in and it ran. So they basically all had their own min-os hardware routines written in assembly to do common tasks normally handled by an os these days.

  • @jonkelly5562
    @jonkelly5562 ปีที่แล้ว +34

    Small startup teams are incredibly productive. Giant teams with Project Managers, Scrum Masters, daily standups, etc are what slows things down. Bureaucratic red tape kills everything. Take Facebooks 5 top guys and let them work 100% autonomously. See what they can create.
    Nothing ever written in "older style" code could support 1 billion users.

    • @chickenbroski99
      @chickenbroski99 9 หลายเดือนก่อน

      I don't think that's the point, Jack. The point is baked into all of this advancement is also un-necessary complexity that reduces the ability and increases amount of work needed to achieve certain results. Try to keep up buddy.

  • @zosoo7
    @zosoo7 2 ปีที่แล้ว +13

    I guess we shouldn't be surprised that software dev is following the same pattern as most other technological advancements. Something tends to be lost when something is gained technologically.

  • @paul_wiggin
    @paul_wiggin ปีที่แล้ว +1

    All the problems he listed are the consequences of management and risk-driven decisions.
    Operation systems were made incompatible intentionally - to lock the user into its ecosystem, to force developers in est time and effort to build programs for one OS.
    And the tech giants like Facebook are slowly changing because they are afraid to change things that work, they have other leverages to stay competitive, like buying, or pushing out the market their competitors with raw resources.
    And containers of different kind are needed because of dependencies with numerous versions that are usually incompatible.
    Yes, we can include compiled and ready for execution dependencies, but this leads to huge amount of memory required just to store/transfer them between the systems.

  • @twigsagan3857
    @twigsagan3857 11 หลายเดือนก่อน +2

    I have had one year of total freedom in my job. I used it to set up everything the way I wanted it. TDD (actually writing tests first), CI/CD, continuous delivery (so no, not branching with git). Then I started hiring people and now I have 8 developers in my team. I taught them everything I know. And now I work in a company with 0 legacy code, perfectly readable tests. I've literally created valhalla for myself, but only because I had no co workers for a year and management that gave me enough trust to get this stuff done.

  • @StevesRepairs54
    @StevesRepairs54 11 หลายเดือนก่อน +1

    The bigger the company the more safeguards are in place which requires more input and review to release.
    I had a text change on a button take 4 days to get approved. Then when we switched our instance from a xlarge to a medium that took about 4 months of getting sign offs and approvals. All of which was 3 lines in terraform.

  • @jgunther3398
    @jgunther3398 2 ปีที่แล้ว +13

    you can still write a simple operating system in assembly language like ken thompson if you want to. i do not think anyone will call it productive...

  • @scottfranco1962
    @scottfranco1962 2 ปีที่แล้ว +15

    You can still statically link programs, and I would argue that this is a better model in any case. Flatpacks and other such solutions carry the dynamic link libraries with the program, but that is essentially what static linking does. Plus, most of the incompatibilities are from the .so/.dlls in any case. The underlying OS calls don't change (the actual calls to the kernel). Finally, using a TK instead of direct interface to the graphics subsystem solves most of the other issues.
    I advocate static linking myself, and I find it hard to believe people are yelling at me "you are wasting memory!". A megabyte is what now, a fraction of a cent in terms of ram, and you are worried about that. Statically linked programs load faster and are more stable than .so/.dll programs.
    Finally, I make all my programs live in a tree in user space. Scattering the program and files all over the operating system not only makes installation harder, but it makes the program parts harder to find and uninstall or update without an automated uninstaller/updater. For example, Eclipse is a very complex program, but it lives in a tree in a user directory. In this case installing consists of copying or unpacking a tar.gz file.

    • @KANJICODER
      @KANJICODER 2 ปีที่แล้ว +2

      I statically link my programs. The only problem is if you make a program with a few gigs of assets and then does it really make sense to embeds all of those assets in your .exe ?

    • @scottfranco1962
      @scottfranco1962 2 ปีที่แล้ว +7

      @@KANJICODER YES. That's why god made virtual memory. As in you stuck it in the binary, and its up to the OS as to how it wants to optimize loading its pages or not, or even shifting those pages to near line memory.

    • @jamhamtime1878
      @jamhamtime1878 2 ปีที่แล้ว +1

      It's also about disk space....
      If you've ever worked in a bigger projects, you'd know that a lot of libraries are linked dynamically for edge cases, as well as more support. In which case, if you link it statically the final executable can increase by tens of MiBs to even hundreds of MiBs of just bloat
      Now this might just be another problem in on itself where programmers dynamically link to everything they "might not need".
      If you've ever used gentoo linux, you'd know how much bloat most programs are, but just removing it is not really an option. The average user won't know how to configure the proper flags for their system, that's why those bloat are necessary.

    • @scottfranco1962
      @scottfranco1962 2 ปีที่แล้ว

      @@jamhamtime1878 So for a $79 1tb SSD (Amazon prices), 100 mb is 0.0079 cents. Congradulations! You have saved about 1/100 of a cent.

    • @jamhamtime1878
      @jamhamtime1878 2 ปีที่แล้ว +2

      @@scottfranco1962 for one program, now multiply that to how many programs do you have installed on your computer. I have around 22GB of shared objects/dynamic linked libraries. Sure a program won't use all of them at once, but that kind of redundancy is just a waste.
      You're just being that developer who refuses to optimize their code because it's 2022 and computers are fast anyway, just get a better computer.

  • @startracer
    @startracer 9 หลายเดือนก่อน +1

    The first 90% is always a lot faster and easier than the final 10%

  • @drrodopszin
    @drrodopszin 10 หลายเดือนก่อน +1

    I think many people don't understand the "invisible feature" creep that comes with scaling. Example: a colleague of mine had to fix a bug coming from laptops moved around and connection getting lost as the new router was from another IP address. This was not a bug, as it was not a coding "defect" but it was also not a marketable feature. But it had to be understood, designed and tested just like any "sellable" features. The bigger the usage of a product the more of this has to be implemented.

  • @elietheprof5678
    @elietheprof5678 2 ปีที่แล้ว +37

    And don't get me started on the environmental impact as software gets less efficient, forcing us to upgrade hardware just to keep the same features.

    • @kleozane2781
      @kleozane2781 2 ปีที่แล้ว +7

      For real, I can't even open youtube on my old laptop

  • @robertwallace5498
    @robertwallace5498 ปีที่แล้ว +6

    this speaks to my heart, it is way too complicated to accomplish any task nowadays

  • @rabbitcreative
    @rabbitcreative ปีที่แล้ว +1

    I think Jon's point is being missed by a lot of commenters. Specifically the ones claiming that being-disturbed-while-programming is more likely the root cause than the abstractions. Yes, distractions will hurt productivity, etc. But even if you had zero distractions, you are still dealing with the bureaucracy of the software stack you are using, and because of that, you have little time to devote to programming something new for that project. You are programming, but you are shaking hands, not building something new.

  • @igorkornienko7761
    @igorkornienko7761 11 หลายเดือนก่อน +1

    Idk what is this guy talking about, I wrote a lot of code in most of the companies I was employed, they constantly require new functionality. It was not rocket science, but new features are being added constantly, actually helping operators do whatever they do a little bit faster and you could see it in profit reports. Sometimes I feel unproductive but other times I actually felt I gave them too much value for my compensation, especially during my junior times. Maybe this is facebook-twitter related problem or just american?

  • @michaelatorn8380
    @michaelatorn8380 2 ปีที่แล้ว +55

    Problem with the unix example is that those 3 things are not the only ones currently required for a popular OS. Things like visuals, design, security, sound, compatibility, updates, are completely necessary.

    • @lucemiserlohn
      @lucemiserlohn 2 ปีที่แล้ว +15

      Necessary? For an operating system? Why exactly?
      The OS part of what you call the OS should be as small as humanly possible; everything else is a program running in userspace, and that includes the majority of what you listed there.
      The fallacy is that we think we need all that heavy ballast in the OS itself; and the better design angle is to get rid of it all and just treat it as ordinary software that can be run, but doesn't have to be run; that can be deployed, but doesn't have to be.

    • @michaelatorn8380
      @michaelatorn8380 2 ปีที่แล้ว +15

      @@lucemiserlohn An operating system needs to be user friendly for the majority of people, the tech itself or concepts behind it don't matter for most people. They want something working straight out of the box with the most important features, that's why they pay for mac computers or windows and don't use linux.
      Companies adapt to what the average user or a niche wants, not the concepts.
      Also some things must be linked together, like user authority and reading or writing to files.
      If they were singular models/classes/functions, you would have a lot of boilerplate code, which could be ommited if the system had the dependancy of modules in mind, increasing the speed of the os, productivity of developers on that os and milestones per interval.

    • @lucemiserlohn
      @lucemiserlohn 2 ปีที่แล้ว +16

      @@michaelatorn8380 That is not what an operating system is. That is a suite of software including an operating system hidden somewhere in there.
      Also, please define user friendly. I would argue that depends on which user you're asking whether it's friendly or not.
      Please also note that I did not say anything about users having to be technically minded. You can have an efficient, lean system and still not require the user to know the details about it.
      Also you assumption about Windows and Mac OS is wrong; people don't buy Windows or Mac OS on their own merits, but rather because it is what either comes pre-installed with their hardware, or because it's what they know from somewhere else or what other people tell them to use. For many, many people it boils down to either "does it run MS Office" or "does it run my games"; pretty much any other use case is irrelevant for the average Joe or Jane.
      The fact is that a lot of the technology that is en vogue today in the software world at large is problematic at best; we have those insanely fast machines and the software we use on them still manages to bring them down to a crawl. And that is the real shame in today's computing world.

    • @blop-a-blop9419
      @blop-a-blop9419 2 ปีที่แล้ว

      You're completely missing the point, out of ego hurt.
      And it's understandable, since his examples and criticisms of 'modern programmers productivity' is ludacrisly stackhanovist. "If you can't invent an OS in 3 weeks then you're trash"... Yeah ok lol, F U.

    • @SKC_car
      @SKC_car 2 ปีที่แล้ว +5

      @@michaelatorn8380 Visuals, design, security, " look pretty "; pretty its different for everyone, yes I do thank having nice UI, but sometimes it gets stupid, like an overdesign, If i bought windows I want to use windows, not mac, then why is W11 looking like mac? as I said, if i wanted a mac id buy a mac, get ur sh*t together and follow a philosophy

  • @coolcat23
    @coolcat23 ปีที่แล้ว +1

    It is inadequate to judge productivity by dividing changes to the software by number of employees. Are all the employees developers? No. Does productivity scale linearly with the amount of developers? No. Is it as easy to perfect a product compared to getting the first version of the ground? No.
    His point about shading languages essentially boils down to a lack of abstraction. If the differences between the different languages could be removed or ignored, the problem he mentions would disappear.
    He created very good games but this talk is a reminder of the fact that one should talk about what one really knows and refrain from talking about things one has an opinion on without truly being an expert.

  • @EdsonMedina
    @EdsonMedina ปีที่แล้ว +2

    TL;DR: "Everything new is bad, old days were perfect"

  • @QuantumMechanic343
    @QuantumMechanic343 10 หลายเดือนก่อน +1

    The examples given near the start of the talk don’t match up with the explanations given at the end.
    One of his implicit assumptions in his first example was that Twitter hired a lot of engineers to program new features. From that assumption he concludes that the engineers are not being productive because of the ratio between engineers and new features.
    We now know that Twitter hired engineers to give the appearance of growth and increase the perceived financial value of the company, and not necessarily to build and push a bunch of new features.
    The issue in his practical example does not lie with the tools being used to build software, but rather with free market capitalism.
    The rest of the talk is an argument that the complexity growth in software tools is not worth it overall. The issue with that argument is that he isn’t explicit in the metric he is using to measure what makes software “good”.
    By the end of it, I was pretty sure that his issue was with how the monetization of software has impacted how we create software. I’m not sure that he realizes that though.

  • @sulton-max
    @sulton-max ปีที่แล้ว +1

    I see it form this simple perspective - we have abstractions only because of advancements in different areas too frequently so releasing new versions for that would be very time consuming, for example imagine you have a software that you wrote in low level programming language and then one of the OS you support introduces a new algorithm to their API, now instead trying to recreate that algorithm in your software you may want to take advantage of that feature, so you introduce different OS SDK s into your system, there you start creating abstractions because without it, you need to create dozens of parallel versions of your software

  • @_TommyP
    @_TommyP ปีที่แล้ว +2

    Don’t forget the ten layers of dev ops that goes on top

  • @chillappreciator885
    @chillappreciator885 2 ปีที่แล้ว +6

    Well I guess at a time when Unix was written programming was something nerdy for scientists. And the market with all this managers/business analytics was not affecting the programmers work flow that much. Now you need make people that far from technology believe that you are actually working.

  • @jonmoore176
    @jonmoore176 23 วันที่ผ่านมา

    I remember getting anything to work on MS-DOS was a pain particularly games with all the different hardware and drivers. It wasn't all rosy back in the day. All software was simpler then but now it is more complex and less hardware limited.

  • @rabbitcreative
    @rabbitcreative ปีที่แล้ว +1

    I get a strong sense of similarity between his description of the bureaucracy of software and the bureaucracy of politics. A lot going on but most of it is ceremony.

  • @batner
    @batner 11 หลายเดือนก่อน

    3:00 Twitter and facebook have a lot of backend software development to optimize it for performance and cost.

  • @pixboi
    @pixboi ปีที่แล้ว +1

    I don't understand what this kind of argumentation is meant to achieve. We used to pick potatoes by hand, now we use tractors. We used to calculate with our hands, now we have calculators. All this progress is positive, in math, the education has more depth and students today can tackle new problems faster, problems that carve the nature of math at a much deeper level. This is just some old as dust boomer doomsaying by a guy who has somewhat authority because he made a couple successful games. This perspective is that code itself or the practice of coding (cough, excuse me, programming) is some kind of virtue, no matter what that code achieves, while the more practical view is, what the code does, what kind of value does it add to our society.
    Also, he seems to measure productivity by the amount of lines written, while the real measure of productivity is tightly coupled to the end result. If we held a competition to make a game in one day, one guy would start from scratch and one would use an engine, the engine guy would win by lightyears.

  • @multiHappyHacker
    @multiHappyHacker ปีที่แล้ว +1

    pretty sure we can blame over-use of OOP for this, they end up working around/fighting with the structure that they themselves have created, to abstract away things that they didn't even need to.

  • @br3nto
    @br3nto ปีที่แล้ว

    0:32 and soon we will be primarily coding in proompting language. The smart proompter will output directly to the lowest language possible. Machine code only. Not human readable.

  • @kerm1t2
    @kerm1t2 ปีที่แล้ว +1

    true, over time programs that once worked become incomptible due to additionals layers of digital signatures etc.

  • @yp5387
    @yp5387 2 ปีที่แล้ว +5

    I don’t like managed languages. I can do pointers but at the same time I don’t want to spend my whole weekend figuring out memory leak on production.

    • @maleldil1
      @maleldil1 2 ปีที่แล้ว +4

      You say you don't like managed languages but point out one of the main problems that led to their creation. If you want to decrease your chances of having a memory leak, you use a garbage collector or something like Rust (maybe C++ with clang-tidy, but that's not as comprehensive).

    • @JuvStudios
      @JuvStudios 2 ปีที่แล้ว

      @@maleldil1 Just use RAII wrappers for everything "owning" and you'll never get a memory leak again.

    • @Muskar2
      @Muskar2 ปีที่แล้ว

      Memory arenas and circular buffers are common solutions to memory management problems - you only do very few permanent memory allocations for each subsystem and then never worry about it again. If you program specialized batched functionality instead of generalized and atomized object-lifecycles then it gets a lot easier - because you can just step through the code and literally see what's going on without keeping track of complex blackbox states (and their possible synchronization requirements). Similarly, multithreading is often deemed very complex and costly but if you see "critical sections" as an inherent design mistake, then it becomes virtually a non-issue to manage.

  • @twocauses
    @twocauses ปีที่แล้ว +9

    As a non-programmer (teaching myself how to code right now), but a kid that always wanted to become one, I now realize after many years my younger self thinking "wait a second, WHY exactly is that?" while learning anything actually meant I was thinking like this.
    I literally couldn't agree anymore on this, this is incredible how accurate it feels to what I've always been thinking.
    Thank you for uploading this video.

    • @adtfor
      @adtfor ปีที่แล้ว +7

      He is talking nonsense to be honest. Ten years ago we couldn't have imagined what kind of sophisticated programs we're going to have, he is pointless. Programs are advancing, market is very demanding, competition is very high. You can't afford writing in assembly or C unless it's absolutely necessary. Point about Ken Thompson is utter bullshit, first Unix was pretty simple, and Thompson is one of the strongest engineers out there. Software development is in its current state is not at all caused by some accident. It's a very competitive market, no one can afford to build their own stuff from scratch (like web-frameworks, game engines, etc.), to learn memory management for 10 years. What Ken Thompson would do in 2 weeks modern Jr. Sw Engineer could import with one command or install in 10 seconds (talking about productivity). He just pulled it out of his ass.

    • @szymoniak75
      @szymoniak75 ปีที่แล้ว +6

      uh, no offense but it seems that's why you are 'a non-programmer'

  • @XxfishpastexX
    @XxfishpastexX 2 ปีที่แล้ว +13

    I’ve noticed that most of the apps, websites, computer games, software that I use at work are very buggy and badly designed. They crash and lag and slow down even when the program itself is not very complicated. I think that the talent pool in the industry is diluted and that new employees are getting lost on the code previously made by former employees.
    TH-cam is the one of the worst offenders. It seemed that they’ve been messing with the code too much and are unable to recognize when it’s time to stop updating and revising the programs. It has bugs that weren’t there a few years ago. The algorithm has changed and doesn’t perform as it used to. Certain UX features now cause problems with playback.
    Maybe someone can help me understand why this seems to be the case or if i’m not taking into account important variables on my statement. I’m an amateur programmer so i’m quite ignorant.

    • @DoisKoh
      @DoisKoh 2 ปีที่แล้ว +7

      As your application grows, it gets significantly harder to maintain. Changing one small piece can have large effects on other parts of the system. TH-cam has actually added a lot of features, including 'Download', 'Clip' and 'Super Thanks' etc. for the end-user, and a lot of analytics tools for creators. They've also done a lot of experimental changes to layouts, removed the dislike counter display etc.
      Some features might seem extremely simple but implementing them at the tremendous scale TH-cam does has many other issues you need to deal with. If you think the 'like' button is just about storing a 'like' counter in the database, you're probably right, but it's not that simple. Every 'like' is going to be associated to the person who did the 'like' (you can view your list of liked videos), so it's possible they store the 'like' as an association between your profile and the video that you like... but if it's stored that way, how are you going to display the counter now? It's not just querying one value from the database, you now need to aggregate all the likes from all users every time the video page is visited (so that you can display that updated value to the visitor) - imagine having to search through all users' profiles, looking at whether they liked that video, and counting that as '1 like', adding all of that up and displaying that as a number on the video page every single time someone visits it. This is obviously incredibly inefficient though you get the most up to date like-count this way. TH-cam almost certainly stores and reads the 'like' counter directly for the page, and then periodically updates it based on aggregating the likes across users; this is why you don't see the like/view counter updating in real-time or changing every single time you refresh the page.
      Now what about providing notifications to the uploader about a video that was liked? How do you efficiently store data that's going to be queried by hundreds of millions of users everyday? Do you need a distributed in-memory cache to handle the like counter and write that value to the database much less frequently? What about when a video gets liked and unliked and liked again? What about the recommender systems that interact with a video's like count? Should a creator wake up to see 10,000-100,000 notifications on a video for all the likes and comments? Can you imagine maintaining a site that deals with 1 billion hours of video uploaded every day? There's a lot of engineering going on that you can't see to enable the site to run so smoothly at this scale.

    • @gmodrules123456789
      @gmodrules123456789 ปีที่แล้ว +3

      TH-cam’s backend is solid. Frontend has always been a trade off between usability and aesthetics. TH-cam at this point seems to prefer aesthetics.
      Software quality hasn’t really gotten worse. People today don’t remember the reams of awful corporate GUIs and win32 apps built in the 90s and early 2000s. Apps that had the possibility to bluescreen your computer if they crashed (as opposed to just crashing the browser).
      I think people mostly remember the games. Specifically, the games that were good. Plenty of bad, buggy, and slow games were made in that era too.

  • @rabbitcreative
    @rabbitcreative ปีที่แล้ว +1

    8:55 This man said it. Thank-you. Thank-you.

  • @QuicksilverSG
    @QuicksilverSG ปีที่แล้ว +7

    It doesn't matter what language you program in anymore. On any modern platform, all you're really doing is feeding parameters to application programming API's, which you're orchestrating to obtain access to operating system services that implement the functions you need to automate. You're basically just embellishing the platform''s built-in functionality with your own branded UI, combined with whatever external content you're bringing to the table.

  • @sovahc
    @sovahc ปีที่แล้ว +1

    I write code at least 2x times smaller than others all the time. A team of five programmers produced about 80 percent of the excess code.
    Imagine if you have 100 of them…

    • @HansBezemer
      @HansBezemer 11 หลายเดือนก่อน

      It's the kind of people that write code like:
      if (x=0) then return (12);
      else if (x=13) then return (1);
      else return (x);
      Instead of: return (((x+11)%12)+1);

  • @jgrif7891
    @jgrif7891 ปีที่แล้ว +1

    I think a large portion of the issues come from how tightly coupled certain software is. Good luck working with k8s without docker or podman. Did you just want a simple drop down in a front end? Well you're going to need 65 packages and one of them IT won't let you use because it has a vulnerability (hyperbole, but only just).

  • @wastedkafir9134
    @wastedkafir9134 2 ปีที่แล้ว +4

    *Just create a small simple UI hello world program in WPF/WCF ie c# and use spy++ to find out the multiple layers of HWND it has created unnecessarily.*

    • @BittermanAndy
      @BittermanAndy ปีที่แล้ว

      This is going to blow your mind, but: the world doesn't need any more hello world programs. No, really! It doesn't.
      The world needs, and people are prepared to pay money for, richer and more complex applications. And that's where UI frameworks come in, for which the stuff you call "unnecessary" has a purpose.

    • @wastedkafir9134
      @wastedkafir9134 ปีที่แล้ว +1

      @@BittermanAndy This depends on the type of development you are doing. Maybe you work cloud based development where 10 extra HWND is necessary.

    • @pretzelboi64
      @pretzelboi64 ปีที่แล้ว

      @@BittermanAndy Funny you say that while most big corpos are literally cutting features out of their apps on the daily. Everything is getting simpler, not more complex. TH-cam used to have full-blown customization for channels and now every single channel looks the same. MySpace allowed music and custom HTML/CSS for profiles, now Facebook, Instagram, TikTok, Reddit, and Twitter are all generic profile pages. You don't know what you're talking about. Like, at all

  • @dpskeptic92
    @dpskeptic92 2 ปีที่แล้ว +2

    From the point of view of just coding that could make some sense, but business related if making an oversimplification of ‘productivity’ , just because you don’t see many features in the apps you mentioned does not mean it takes more time to program, but features go through a life cycle

    • @dpskeptic92
      @dpskeptic92 2 ปีที่แล้ว

      … where many features get shutdown after data analysis, those arguments are not sound after looking at the whole picture

  • @imqqmi
    @imqqmi ปีที่แล้ว

    Part of the problem is the low hanging fruit is gone, aside from unnecessary added complexity. It gets harder to make changes or rather add functionality with increasingly more complex systems, requirements, security and underlying architecture, or the lack thereof. Lack of documentation and descriptions of what things were intended to do etc

  • @LostStylus
    @LostStylus ปีที่แล้ว +1

    3:14 it's incorrect to judge the productivity in consumer-oriented features. First of all there a lot of features that are business-oriented, second there are a lot of underlying challenges like e.g. clustering all that data and making this all work under heavy load, etc. We also don't know what kind of engineers are hired, it could be that a lot of them are actually data analysts and infrastructure engineers that have nothing to do with features whatsoever.

    • @Over-Nick
      @Over-Nick ปีที่แล้ว +1

      "I didn't see anything change so they must not have done anything"

    • @tatarjr49
      @tatarjr49 ปีที่แล้ว +1

      Agree so much, he should have looked at revenue per employee.

  • @MrMichaelfalk
    @MrMichaelfalk 10 หลายเดือนก่อน +1

    Programmers aren't productive anymore because agile....

    • @llothar68
      @llothar68 5 หลายเดือนก่อน

      Because of test driven development which was a tool to sell consulting

  • @Dr.Kananga
    @Dr.Kananga ปีที่แล้ว

    The number of software companies has drastically increased over the last twenty years and so have their product/service offer. In this sea of competition, each brand is chipping in that extra feature to win new clients and sell their software, thus increasing the complexity of the original idea and influencing the developer job market with fads and trends over the need for new requirements. There are companies out there rejecting front-end developers without SASS experience because on their resumes they see only CSS. Food for thought.

  • @octavioavila6548
    @octavioavila6548 11 หลายเดือนก่อน +1

    Now we have the ChatGPT prompt engineering level of abstraction

  • @DoisKoh
    @DoisKoh 2 ปีที่แล้ว +1

    I watched the full original video a while back and I had significantly less experience than I have now.
    I have to say that this ignores the fact that a lot of systems are now distributed to provide high availability, and to scale with the massive amount of users and fluctuation of traffic - and those are legitimately tedious and difficult problems to deal with. There's a lot of infrastructure configuration (for people, hardware, and software all the like). The largest tech companies are successful at managing and deploying software at scales you don't deal with when you create single-player video games. I'm not denigrating Blow's games in any way, I think Jonathan is the best video game designer ever, bar none and the stuff he's made are masterpieces, but the arguments provided on this point are a little bit flimsy.
    The other point he brought up in this talk about 'losing' technology is something really scary that I can't help but feel is totally accurate.

    • @alexmckee4683
      @alexmckee4683 ปีที่แล้ว +1

      A lot of it doesn't need to be built this way to begin with, however. We have entered an age of centralization. Decentralised alternatives could be safer (can't access millions of accounts with one hack), would be more efficient and less prone to walled garden problems arising.

  • @remigoldbach9608
    @remigoldbach9608 10 หลายเดือนก่อน

    I agree with him at some degree : if i see how the web technologies evolve and how fast some technologies are then thrown away, he is right !
    All the Javascript code that is developed to then be rewritten with some other frameworks...

  • @bflmpsvz870
    @bflmpsvz870 11 หลายเดือนก่อน

    I think one of main reasons for this crippling exponential overcomplication is that software is nowadays used in exponentially more interlocked human society senarios. Its probably same with the law. We just live in a complicated interdependent society.

  • @MyUsername09AZ
    @MyUsername09AZ ปีที่แล้ว +1

    Nobody nowhere works anymore. No wonder that includes programmers.

  • @RowanGontier
    @RowanGontier 11 หลายเดือนก่อน

    Depends on how you define productivity. I feel a lot more productive now than 20+ years ago. But I need to consider more things now for any user equirement. You can't base productivity on the time it takes for you to say "job done". It is like comparing the project time for a tiny house and a skyscraper.

  • @CrazyHorseInvincible
    @CrazyHorseInvincible ปีที่แล้ว +1

    9:05 You need a manifest and you need to sign your code, you say? Why the fuck do you think that is, Mr. Blow? This guy is waxing poetic about superpowers we supposedly had in the Windows9x days when every program had the potential crash the fuck out of your computer, and did, routinely, to a point where you couldn't keep the machine running for 4 straight hours.

  • @testboga5991
    @testboga5991 11 หลายเดือนก่อน

    The issue is the same as in every industry: returns over effort decline with complexity. Great analysis!

  • @FlorisDVijfde
    @FlorisDVijfde ปีที่แล้ว +2

    Twitter and Facebook are awful examples, most of the staff are not programmers at all. At Twitter, Musk fired almost 80% because they were censoring all day.
    There is also the large company's disease of being inefficient for wasting too much time on meetings and increased bureaucracy.
    As an indie, Jon Blow does not have these problems. However he may encounter performance issues that require very specific knowledge and experience. Even the large companies can have difficulty finding it.

  • @orlovskyconsulting
    @orlovskyconsulting 2 ปีที่แล้ว

    This is old debate generalization vs specialization , well i say as consultant it depends, in some areas you must be generalist and in some not, it's really a big challenge in the industry , but solution as always manage yours and other expectations and be honest about estimates.

  • @Jeevanm71
    @Jeevanm71 11 หลายเดือนก่อน

    The objective of abstraction is to get high level functionality for cheaper costs. You can take cheap novice dev talent and have them code in Java and you can still deliver and it’s significantly easier to do that at an enterprise level

  • @genghischan69
    @genghischan69 ปีที่แล้ว +2

    Is everyone just going to ignore that it took Ken Thompson his wife to shut up for 3 weeks to advance our civilization forward?

  • @BryonLape
    @BryonLape 2 หลายเดือนก่อน

    I coded back in those days. You couldn't easily do those things either.

  • @hiryu70
    @hiryu70 ปีที่แล้ว

    Now progmmers work on the field of hypothesis that can provide apportunities for business. You write code and and test in market. There very small core fundamental features, that should be effective and optimized, you can balance it with cheap hardware.

  • @SimonM90
    @SimonM90 ปีที่แล้ว +1

    I think just measuring people to such high standards of productivity is the mistake rather then "the tools are making us dumb". I know a few productive people who are able to learn and use low level tools rather naturally but it's like an extreme end of productivity that you should not measure everyone else to. Also, yeah, Ken Thompson did write unix in 3 weeks (which to me seems like a beergarden story anyway), but not everybody is Ken Thompson...

  • @paulsaulpaul
    @paulsaulpaul 11 หลายเดือนก่อน +1

    So he said he made Unix in about 3 weeks, but how secure was it? By modern standards? Can't just churn out assembly code and barenaked C with no unit testing and ship that as an OS these days. Or any sort of software these days.
    edit: This guy's way out of touch. And I'm a 41 year old neckbeard saying that. He's associating corporate productivity with system complexity and abstraction. I don't think think the three have to be correlated. He's forgetting about massive advancements in hardware and connectivity that require these complex abstractions so your software isn't trivially exploited by moving a pointer in memory or feeding bad data into a program.
    And then he ends it with a rebuke against code signing. /eyeroll emoji
    He should go write his assembly in vi and use a magnet to flip his bits in his RAM. Imagine he produces anything useful...

  • @jozefbania
    @jozefbania ปีที่แล้ว

    Nobody is doing lego bricks from scratch anymore but you must use predefined legos and sometimes well the legos cannot build what you want and you must do crazy construction to get the job done. Nasty.

  • @lucysluckyday
    @lucysluckyday ปีที่แล้ว +2

    Pure productivity slips with disturbances - open plan offices (noise) and working from home (ability to sleep on call), meetings with the product teams. But its complexity and quality demands it in the modern era. And as he says, dev ops is now a necessity.

    • @gediminasmorkys3589
      @gediminasmorkys3589 ปีที่แล้ว

      Dismissing work from an open office and work from home leaves precious few options, doesn't it? Sounds to me like looking for excuses to not work 😉

  • @ChrisM541
    @ChrisM541 10 หลายเดือนก่อน

    A programmer's ability/requirement to 'program' reduces as their chosen language/s abstract further away from assembly language. Equally concerning, the percentage of poor programmers increase the further their chosen language/s abstract from assembly.
    0:06 Correction - no one ever programmed in machine code! Why? because every CPU, including the very first one, has a mnemonic (assembly language) version of the instruction set - all the opcode mnemonics and associated operands were known from day #1. With that, all programmers in the early days wrote in assembly language, for very obvious readability/debug/QC/etc reasons. At the same time, the machine code numeric opcode (and operand when applicable) was written next to each line - and it's this numeric version that was entered into the computer.

  • @Andrew-rc3vh
    @Andrew-rc3vh ปีที่แล้ว

    I see videos on here regarding people installing a program in a Linux environment using the command line. Of late I have noticed this task can get so complicated that it is way more difficult to understand than back in the old days when one would write a basic program and then type run. To give credit where credit is due, at least in Window's land the machine is intelligent enough to do all of that nonsense without troubling the user. The idea of press one button, go and have a cup of tea and then it will all be working in five minutes in the default configuration which you can twiddle with as and when the need arises. Linux stuff seems to be all the crazier where it meets these tiny customised single board computer modules that are popular these days, e.g. like RISC5.

  • @ayyubayyyub9415
    @ayyubayyyub9415 2 ปีที่แล้ว +1

    Is he trying to state that we have to create everything from scratch without frameworks and libraries just the programming language.

  • @1over137
    @1over137 2 ปีที่แล้ว +11

    So in your world, what do we do? I can see it from a game centric attitude as we could still technically produce a "bin file" on a filessystem, under the OS and use a bootloader menu to choose "Generic OS Windows" or "Game Engine XYZ". Using EUFI to access that file system, load the first 640k of the executable into RAM and "call 0" on it in superviser mode 0. Boom, no OS. No security, no network, no filesystem, no locks, no IPC, no display abstraction, you'd need to write all that yourself.
    I suppose that fine for little games, but big games or games with extensive file, network access and games that reuse large amounts of the OS's GUI would need to completely rewritten.
    Of course people would come out with templates and containers to build for that gets them running on that one single architecture AND handle all the millions of possible hardware combinations. This ISNT playstation! It's PC.
    Not going to happen.
    OS's stink, but they are here to stay. Even if by solving EVERYONE ELSES problem they slow and complicate your problem. What can we do?
    If you think software developers are unproductive because of the OS... you need to go spent a tour of duty working in the real world, like financial services, then you will understand why software developers are non-productive.

    • @1over137
      @1over137 2 ปีที่แล้ว +5

      @Georgios Kotzampopoulos It really depends on where you work, what sector etc. The issues I am seeing in global enterprise is one of capacity. There isn't enough engineers. There is more demand for software rewrites or upgrades due to changing global regulatory features which have impact across the board. The demand for software is high across most industries. However the number of "graduate" or "retrained" staff of any quality is not increasing.
      The other side of capacity is the loading factor and what seems to me to be happening is management will hire lesser and lesser staff to try and increase numbers and increase productivity and give increasingly short deadlines.
      Tying it back to Johnathon's concepts of complexity and quality. Management see software line items as digital. Done or not done. There is no spectrum of quality in their view. If a 10 year+ engineer gives as estimate of 8 days and a junior gives a 2 day estimate. Management will take the 2 day estimate. Quality is not part of their agenda. Getting the work "complete" and off their status board before they have their management breathing down their neck.
      Quality issues surface later. Finding the hacks and corners cut, 0 documentation and silo'ed teams cowering in their scrum bubbles unable to help other teams, unwanting to help other teams.
      Everyone wading in a sea of half done code, poorly down code, hacks, walking a path through development with massive fragile overhanging architecture that could avalanche on you at any time.
      How do they keep it all running? By having 1000s of people around the world holding it up 24/7 thats how.
      But they met the dates.
      I personally have gone on record lately that I refused to sign off on a production release, refused. The code was NOT ready.
      They pushed it to prod anyway, in March. I'm still fixing production bugs now in August. Fix your bugs in DEV. It's much, much easier, once in prod it's a nightmare.
      As a tech lead I am constantly over-ruled in best practices by the customer. I will tell my team, "Please don't write software like "that"." A day later the customer explicitly asks for it to be done that way, because of some rubbish reason about legacy issues or "thats the way we always do it."
      Quality is dropping pretty fast. Complexity is rising fast, but the knowledge and experience of how to diagnose that complexity is waning. Low quality + complexity not only makes hard bugs more likely, it makes them next to impossible to isolate, define and fix.
      (Sorry I'm ranting at you :))

    • @1over137
      @1over137 2 ปีที่แล้ว +3

      "Everyone should go agile!"
      This works great until you try and explain that to the customer during the financials meeting.
      "So you are trying to tell me, either I can pay for a fixed amount of time and have no idea what I'm getting for that money at the end OR I can pay a variable amount for a fixed set of requirements and you can't tell me WHEN I can get it?"
      Trust me. It's not easy to sell. It's next to impossible to sell and if you think about it from the customers point of view, it IS hard to swallow.

    • @1over137
      @1over137 2 ปีที่แล้ว +4

      @Georgios Kotzampopoulos Good points. Good questions. I think the revolution will come, just like it has before. I'm looking back at COBOL and Fortran days. Paying programmers by the KiloLines of code etc. 1970 and 80s. Software became untenable, unmaintainable, high profile, high cost failures globally, companies out of business because of broken software. In the 90s, most software engineers just said, "No. I won't work on your COBOL. Nobody does that anymore.", the cost of running legacy COBOL systems went through the roof. By the 2000s the vast majority of enterprise has migrated away from that legacy "mainframe" engineering. (There are still mainframes and they are still running legacy 1970s banking products to this day, but a IBM mainframe COBOL programmer will cost you a pretty few grand a day).
      I foresee something similar coming. The Software explosion of the 2000s-2020s with nearly the entire planet coming into the online world is creating a kind of "honeymoon bubble" where industry and users are accepting of the rubbish quality. I see that waning and more and more pressure being put on the current engineering methodologies are how they are managed. Eventually the profession will revolt and just start turning down job offers for companies who still want to treat engineering like mechanical labour and engineers like cookie cutter, one size fits all, "fungible resources" and more like the artists and creative flesh and blood people they are. Software is organic. Even the CEO of Sun Microsystems is famous for saying it should never have been called Engineering, it should be considered a creative art.

    • @SimGunther
      @SimGunther 2 ปีที่แล้ว

      @@1over137 With "agile" development, you're basically enforcing the waterfall model per ticket instead of per quarter with a batch of features. Yes, I get that you must fix every issue that pops up first before creating new features, but there's a point where you must put a filter upfront to say "we hear that these are issues y'all are facing, but we're either going to address it by the end of the quarter, have a live patch if this is a very serious issue that must be fixed ASAP, or we just don't address it at all because it's not the most business critical issue on our plate."
      Something tells me that people might be using web browsers in so many ways it was never intended to be used like an ad/consumption funnel or a slow "live" POS application instead of a simple web of document repositories like originally intended...

    • @C4IMaKeR
      @C4IMaKeR 2 ปีที่แล้ว

      Could you please explain the "Using EUFI to access that file system, load the first 640k of the executable into RAM and "call 0" on it in superviser mode 0" part?, I did google it before writing this but couldn't get any useful info, no googling skills? who knows.

  • @4xelchess905
    @4xelchess905 ปีที่แล้ว

    Productivity going down as projects grow bigger is nothing surprising. It's the same in every single industry. Decreasing yields. Once low hanging fruits have been picked, once you factor in the cost of communication, scaling, of course productivity is going to decrease.
    Now there are a some legitimate specific points mentioned in the videos and in the comments of things that could be improved.
    But for the most part, decreased productivity is expected and no big deal. It's literally economics 101. marginal cost increase and marginal gain decrease and companies are rationally expected to keep producing until their marginal profit zeroes out. It may be depressing for individual, and I for one much prefer green fields, but it's being extremely naive to expect the same level of visible innovation (new features) now as there were from an era with few and exceptional dev and most of the tools were yet to be made.

  • @MrAbrazildo
    @MrAbrazildo ปีที่แล้ว +1

    4:35, this was truly amazing!

  • @JustMWest
    @JustMWest ปีที่แล้ว +1

    That's an interesting way to measure productivity

  • @toonsoffun5733
    @toonsoffun5733 11 หลายเดือนก่อน

    Companies like Facebook main concern is scalability and advertising. The end user can’t really pinpoint what core functionality has changed.

  • @freakinccdevilleiv380
    @freakinccdevilleiv380 11 หลายเดือนก่อน

    Excellent, thank you.

  • @trueriver1950
    @trueriver1950 2 ปีที่แล้ว +10

    One of the reasons the OS removes capabilities is deliberate: it's to predict intellectual property by drastically limiting portability. That, it seems to me, is the entire purpose of the "registry" that MS introduced in W95. That's not the only example, it just happens to be historically the first one I noticed at the time of introduction.