this post was submitted on 15 Oct 2024
318 points (99.4% liked)

Programming

23242 readers
312 users here now

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person's post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you're posting long videos try to add in some form of tldr for those who don't want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



founded 2 years ago
MODERATORS
top 50 comments
sorted by: hot top controversial new old
[–] 0x0@programming.dev 155 points 1 year ago (8 children)

Technical debt is the number one cause of developer frustration. Working with imperfect systems demoralizes programmers, making it difficult to do quality work.

I'd wager not being given time to tackle technical debt is indeed frustating...

[–] zqwzzle@lemmy.ca 45 points 1 year ago (1 children)

It’s hilarious when the identified problems come back around to bite the organization, when the priorities have been to work on poorly specc’d features instead.

[–] Tanoh@lemmy.world 19 points 1 year ago (1 children)

But then it is the developers fault, never management

[–] sorval_the_eeter@lemmy.world 10 points 1 year ago

Seen a lot of that too. Execs who thinks all the devs are idiots and would be lost without their genius guidance, phoned in from a luxury remote location while all of us have to return to the office full time. Then stuff fails and we "pivot" to the next badly thought out fiasco. I guess it pays the bills.

[–] Croquette@sh.itjust.works 24 points 1 year ago

Yeah, that's probably more the issue. We've seen too many times throwaway code become production code because "it works already, we need to move forward".

[–] FizzyOrange@programming.dev 16 points 1 year ago (2 children)

The secret is just to do it anyway. I have yet to work in a job where anyone actively stopped me fixing technical debt, even if they never asked me to do it.

[–] IllNess@infosec.pub 15 points 1 year ago

Depends on the work load. The company should make time for that and you should get paid for it.

[–] 0x0@programming.dev 12 points 1 year ago

Use overestimation padding, eh?

[–] sorval_the_eeter@lemmy.world 16 points 1 year ago* (last edited 1 year ago) (2 children)

I keep seeing a pattern of sre/devops/sysadmin tasks being given back to developers and canning the SREs. Hard to understand why. Then some of the SWE get stuck basically focussing on infra SRE stuff and become unwilling SRE more or less. Circle of life? Do the old devops folks get made into glue or something?

[–] 0x0@programming.dev 13 points 1 year ago (2 children)

Do the old devops folks get made into glue or something?

If i interpreted the "trend" correctly, "devops" was bastardized away from its original meaning to now mean "sysadmin", at least in most cases.

[–] MajorHavoc@programming.dev 5 points 1 year ago (2 children)

Yeah. A "DevOps" is just a "sysadmin" who can pretend they don't hate all developers for stretches of 20 minutes at a time. (I'm kidding. I know our SysAdmins love us... In their own secret ways.)

load more comments (2 replies)
load more comments (1 replies)
[–] djnattyp@lemmy.world 6 points 1 year ago* (last edited 1 year ago)

"Devops" original intent meant you don't have a separate "operations" department separate from teams "developing" your product / software due to competing incentives. "Dev" wants to push new stuff out faster; "ops" wants to keep things stable. Or "dev" needs more resources; but "ops" blocks or doesn't scale the same. The idea was to combine both "dev" and "ops" people onto projects to balance these incentives.

Then managers and cloud clowns repurposed it to apply to every person in a project so now every member is expected to perform both roles (badly). Or even more overloaded to somehow refer to "developer infrastructure" teams.

[–] Cold_Brew_Enema@lemmy.world 11 points 1 year ago

It is. Source: We've had the same issues for years, but never get any time allotted to fix them.

load more comments (2 replies)
[–] explodes@lemmy.world 104 points 1 year ago (3 children)

I would say 80% of employees are unhappy, but I don't have any data to back this up.

[–] SpeakinTelnet@programming.dev 46 points 1 year ago (7 children)

Can confirm. Was quite unhappy in my mechanical engineering job, had an opportunity to develop something nice in python, was told we'd do it in excel/vba instead, still unhappy.

[–] MajorHavoc@programming.dev 9 points 1 year ago (2 children)

was told we'd do it in excel/vba instead, still unhappy.

I just threw up in my mouth a little. Fifteen years ago, "I'll stick to Excel" was a (bad, but) defensible position in data automation. Today that's just insanity.

load more comments (2 replies)
[–] ProtecyaTec@lemmy.world 8 points 1 year ago
[–] sorval_the_eeter@lemmy.world 6 points 1 year ago

Nice. You can put that on your resume so you can get more of those kinds of jobs.
(/s. I like excel to a point but i really feel your pain too-- and fuck vba)

load more comments (4 replies)
[–] MicrowavedTea@infosec.pub 14 points 1 year ago (2 children)

Or maybe 80% of people are unhappy. No data here either

[–] Sauerkraut@discuss.tchncs.de 15 points 1 year ago (2 children)

80% seems too high, but the US Surgeon General declared a loneliness epidemic https://www.hhs.gov/sites/default/files/surgeon-general-social-connection-advisory.pdf

And Gallup claims that 29% of Americans have been diagnosed with depression at one point: https://news.gallup.com/poll/505745/depression-rates-reach-new-highs.aspx

So... That is not good. It is almost like humans evolved to live in tight knit, walkable communities.

load more comments (2 replies)
load more comments (1 replies)
[–] sorval_the_eeter@lemmy.world 14 points 1 year ago (3 children)

Every job lately seems to have been infected by Meta/google "data driven" leadership. Its so painful and wasteful sometimes.

[–] lysdexic@programming.dev 11 points 1 year ago

Every job lately seems to have been infected by Meta/google “data driven” leadership. Its so painful and wasteful sometimes.

It's cargo cult mentality. They look at FANGs and see them as success stories, and thus they try to be successful by mimicking visible aspects of FANG's way of doing things, regardless of having the same context or even making sense.

I once interviewed for a big name non-FANG web-scale service provider whose recruiter bragged about their 7-round interview process. When I asked why on earth they need 7 rounds of interviews, the recruiter said they optimized the process down from the 12 rounds of interviews they did in the past, and they do it because that's what FANGs do. Except FANGs do typically 4, with the last being an on-site.

But they did 7, because FANGs. Disregard "why".

[–] booly@sh.itjust.works 9 points 1 year ago (1 children)

20 years ago it was the people who worshipped Jack Welch, not realizing (or not caring) that he was running GE into the ground.

[–] corbs132@lemmy.world 7 points 1 year ago

The Behind the Bastards podcast covered Jack Welch, definitely worth a listen.

load more comments (1 replies)
[–] Technus@lemmy.zip 76 points 1 year ago (3 children)

Will AI steal their jobs? 70% of professional programmers don’t see artificial intelligence as a threat to their work.

If your job can be replaced with GPT, you had a bullshit job to begin with.

What so many people don't understand is that writing code is only a small part of the job. Figuring out what code to write is where most of the effort goes. That, and massaging the egos of management/the C-suite if you're a senior.

[–] MonkeMischief@lemmy.today 35 points 1 year ago (1 children)

If your job can be replaced with GPT, you had a bullshit job to begin with.

This one's funny to me, because the people who WILL try to replace you with GPT don't care if they CAN replace you with GPT. They just will.

Look at how it's haphazardly shoved into everything for no reason whatsoever already.

[–] MonkderVierte@lemmy.ml 6 points 1 year ago (1 children)

Business fails, next business pops up.

[–] MajorHavoc@programming.dev 6 points 1 year ago* (last edited 1 year ago) (2 children)

Yep! And we're in the big tech era, so it can also be:

Business fails to produce any value and uses it's influence to prevent the next business from popping up.

load more comments (2 replies)
[–] fine_sandy_bottom@lemmy.federate.cc 20 points 1 year ago (3 children)

Automation is always incremental.

I'm an accountant. Components of the job have been being automated or systemised for many decades. Most of the tasks that occupied a graduate when I was one 20 years ago don't exist anymore.

Not because AI is doing those tasks but just because everything became more integrated, we configure and manage the flow of data rather than making the data, you might say.

If you had to hire 100 professional programmers in the past, but then AI makes programmers 10% more efficient than previously, then you can do the same work with 91 programmers.

That doesn't mean that 9 people were doing something that an LLM can do, it just means that more work is being completed with fewer programmers.

[–] MajorHavoc@programming.dev 12 points 1 year ago* (last edited 1 year ago)

If you had to hire 100 professional programmers in the past, but then AI makes programmers 10% more efficient than previously, then you can do the same work with 91 programmers.

You've nailed to root of the misunderstanding by non-programmers. We're already optimized past that target.

Some people think we type all day. We don't. We stare at our screen saying "what the fuck?!" for most of the day. Those is especially true for the best programmers doing really interesting work.

There's maybe three living humans who actually know how to correctly build a Windows installer. One of those three is paid to sell software to automate the task for everyone else. The other two retired already. (One is hiding out as a bar tender and claims to not speak any English if recognized from their MSI days.)

Pick an interesting topic in programming, and you'll find similarly ludicrous optimization.

There's a few hundred programmers building all banking automation, selling it to millions of bank employees.

It's possible that AI will force a dozen people to stop doing banking automation. It's a lot more likely that the backlog of unmet banking automation need will instead just get very slightly smaller.

Now, the reality of the economics won't stop CIOs from laying off staff and betting that AI will magically expand to fill the gap. We're seeing that now. That's called the "fuck around" phase.

But we've seen "this revolutionary technology will make us not need more programmers" before (several times). The outcomes, when the dust settles are:

  1. The job is now genuinely easier to do, at least for beginners. (Senior professionals had access to equivalent solutions, before everyone else got excited.)
  2. More people are now programmers. (We laid a bunch of them off, and we meant to not hire any back, but it turned out that our backlog of cool/revolutionary/necessary ideas was more important to leadership than pinching pennies.)
  3. A lot of work that was previously ignored completely now gets done, but done very badly by brand new programmers. (We asked the senior developers to do it, but they said "Fuck you, that's not important, make the new kid do it." I think they're just still cranky that we spent three years laying off staff instead of training...)
  4. The average quality of all software is now a bit worse, but there's a lot more variety of (worse) software now available.

To add on this, this doesn't necessarily mean that there are fewer programing jobs in total. If people work 10% more efficently, that means that the cost of labor is only 91% of what it was before meaning that people might be able to afford to finance more programing projects. One thing that does matter is for example things like entry level jobs disappearing or the nature of the work changing. Doing less boring gruntwork can make the job more fun, but otoh digitization sometimes results in the worker having less agency in what they do since they have to fit everything into a possibly inflexible digital system.

load more comments (1 replies)
load more comments (1 replies)
[–] jjjalljs@ttrpg.network 66 points 1 year ago (1 children)

There's a lot of like management being like "we gotta hit this deadline (that we made up)" combined with "if I hit all my targets and put in some overtime, the boss can buy another sports car this year"

I don't want to work extra to make someone else richer. Maybe if I had a shit load of shares. Maybe. But I don't. So I do my job with professional standards, but I'm not doing 12 hour days

load more comments (1 replies)
[–] CodeMonkey@programming.dev 41 points 1 year ago (4 children)

Maybe it is just my experience, but in the last decade, employers stopped trying to recruit and retain top developers.

I have been a full time software engineer for more than a decade. In the 2010s, the mindset at tech giants seemed to be that they had to hire the best developers and do everything they could to keep them. The easiest way to do both was to be the best employer around. For example, Google had 20% time, many companies offered paid sabbaticals after so many years, and every office had catering once a week (if not a free cafeteria). That way, employees would be telling all of their friends how great it is to work for you and if they decide to look for other work, they would have to give up their cushy benefits.

Then, a few years before the pandemic, my employer switched to a different health insurance company and got the expected wave of complaints (the price of this drug went up, my doctor is not covered). HR responded with "our benefits package is above industry averages". That is a refrain I have been hearing since, even after switching employers. The company is not trying to be the best employer that everyone wants to work at, they just want to be above average. They are saying "go ahead and look for another employer, but they are probably going to be just as bad".

Obviously, this is just my view, so it is very possible that I have just been unlucky with my employers.

[–] mesamunefire@lemmy.world 14 points 1 year ago (1 children)

I've kinda checked out of the private sector for this reason. I've been having a great time working for a government job. Great benefits, union, etc... pay is about 80 percent of what others make but it's more than enough to get by.

[–] ripcord@lemmy.world 5 points 1 year ago (2 children)

Man, I'd be happy with 80% of what I get for less stress and more security. What kind of government job specifically?

load more comments (2 replies)
[–] lysdexic@programming.dev 13 points 1 year ago

In the 2010s, the mindset at tech giants seemed to be that they had to hire the best developers and do everything they could to keep them.

Not really. The mindset was actually to hire skilled developers just to dry up the market, so that their competitors would not have skilled labour to develop their own competing products and services.

Then the economy started to take a turn for the worse, and these same companies noted that not only they could not afford blocking their competitors from hiring people but also neither did their competitors. Twice the reasons to shed headcount.

It was not a coincidence that we saw all FANGs shed people at around the same time.

load more comments (2 replies)
[–] Bishma@discuss.tchncs.de 32 points 1 year ago

So, roughly 20% of developers have found the right mix of self-medication?

[–] actually@lemmy.world 22 points 1 year ago (3 children)

I’ve been programming for years, I’ve only happy when working on my own stuff. It’s like the difference between renting and owning

load more comments (3 replies)
[–] onlinepersona@programming.dev 19 points 1 year ago (1 children)

The bloody managers are the biggest problem. Most don't understand code much less the process of making a software product. They force you into idiotic meetings where they want to change how things work because they "don't have visibility into the process" which just translated to "I don't understand what you're doing".

Also trying to force people who love machines but people less so into leading people is a recipe for unhappiness.

But at least the bozos at the top get to make the decisions and the cheddar for being ignorant and not listening.

Anti Commercial-AI license

load more comments (1 replies)
[–] count_dongulus@lemmy.world 17 points 1 year ago* (last edited 1 year ago) (3 children)

The thing that frustrates me about developers who feel powerless over technical debt is...who is actually stopping them from dealing with it? They way I see it, as a software engineer, your customer is sales/marketing/product/etc. They don't care about the details or maintenance, they just want the thing. And that's okay. But you have to include the cost of managing technical debt into the line items the customer wants. That is, estimate based on doing the right things, not taking shortcuts. Your customer isn't reading your commits. If they were, they wouldn't need you.

It would be bizarre if your quote for getting your house siding redone included line items for changing the oil on the work truck, organizing the shop, or training new crew members. But those costs of business are already factored into what you pay at the end of the day.

[–] AdamBomb@lemmy.sdf.org 14 points 1 year ago (4 children)

Yes, this. Refactor first to make the upcoming change easier and cleaner, not after. Don’t ask for permission, don’t even call it refactoring or cleanup. Just call it working on the feature, because that’s what it is. Don’t let non-engineers tell you how to engineer.

load more comments (4 replies)
[–] janAkali@lemmy.one 6 points 1 year ago (1 children)

I believe for many companies, developers work on giant codebases with many hundred thousands or even millions of lines of code.

With such large codebase you have no control over any system. Because control is split between groups of devs.

If you want to refactor a single subsystem it would take coordination of all groups working on that part and will halt development, probably for months. But first you have to convince all the management people, that refactor is needed, that on itself could take eternity.

So instead you patch it on your end and call it a day.

load more comments (1 replies)
[–] BilboBargains@lemmy.world 16 points 1 year ago (3 children)

I feel blessed that I like my current job. Good manager, interesting work, limited amounts of bureaucracy. Most of this is a lucky coincidence but there are some things we can do. I had to explain many times to people which tasks I'm good at and which ones they should ask other people to do. I regularly defend this position. I set aside the morning for creative work only, no meetings, no admin, just thinking and solving. In the afternoon I down tools and do something physical, outside in daylight. A regular sleep cycle is absolutely critical for the maintenance of health and mood. Fresh food and companionship. Regular meditation. Do the basics well. These are the things that have made me happy.

Sounds like you're well paid and your time is valued, I imagine most devs would be happy with that!

load more comments (2 replies)
[–] GhiLA@sh.itjust.works 7 points 1 year ago

Reinforcing my headcanon that everyone is.

load more comments
view more: next ›