this post was submitted on 06 Feb 2024
103 points (94.0% liked)

Programming

17768 readers
401 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 [email protected]



founded 2 years ago
MODERATORS
top 50 comments
sorted by: hot top controversial new old
[–] [email protected] 64 points 11 months ago (3 children)

That programming as a career means you're going to spend writing nice, clean code 80% of the time.

It's rather debugging code or tooling problems 50% of the time, talking to other people (whether necessary or not) about 35% of the time and the rest may be spent on actually spending time doing the thing you actually enjoy.

I may be exaggerating, but only a little.

[–] [email protected] 15 points 11 months ago (3 children)

In my experience, you're rather inaggerating. I'm not even 10y into my career and if I get to actually code for 2h a day, that's already a success. Most of my time nowadays is documentation, meetings, jira, research and calls with the clients.

load more comments (3 replies)
load more comments (2 replies)
[–] [email protected] 57 points 11 months ago (1 children)

"We're going to clean up that code later."

[–] BrianTheeBiscuiteer 12 points 11 months ago (3 children)

If you're lucky this statement is actually true 5% of the time.

load more comments (3 replies)
[–] halloween_spookster 45 points 11 months ago (3 children)

Myth: software engineers replicate value similar to a factory worker making the same item over and over

Truth: software engineers are closer to artists than factory workers IMO. We find and create new value, not replicate existing value

[–] [email protected] 26 points 11 months ago (1 children)

And just like artists, the vast majority aren't very good at it.

load more comments (1 replies)
[–] [email protected] 23 points 11 months ago (2 children)

eh, more like self-important plumbers

load more comments (2 replies)
load more comments (1 replies)
[–] [email protected] 44 points 11 months ago* (last edited 11 months ago) (5 children)

That you can just go to a bootcamp, and be good at or naturally suited for it.

That you can go to college and get a degree, and be good at or naturally suited for it.

[–] ShroOmeric 20 points 11 months ago (1 children)

Well that's true for every field.

load more comments (1 replies)
load more comments (4 replies)
[–] [email protected] 41 points 11 months ago (5 children)

That if you know how to code, you understand how computers work and understand really complicated math concepts.

[–] BrianTheeBiscuiteer 16 points 11 months ago (2 children)

That's the difference between a programmer and a computer scientist, but even I (a computer scientist) I'm not an expert in hardware, networking, or OS level operations because that's not my daily focus.

[–] Landless2029 12 points 11 months ago

I compare my career to the medical field. Sure there are some crossovers but lots of specialties.

Would you consult a dentist about your bowel movements?

load more comments (1 replies)
load more comments (4 replies)
[–] [email protected] 36 points 11 months ago (8 children)

That a "working" prototype with no tests is just as good as a carefully-designed and well-tested feature. I see this happen so often that a coder puts a prototype in front of a product manager or exec and they are like, "this is exactly what we need, now! Ship that!" And then misery ensues for all of the engineers that need to maintain this piece of garbage. As managers pressure the engineers to build new features on top, they inevitably break fundamental parts of it, and without a confident leader to demand that tech debt is paid off, that product will consume the souls of many desperate coders.

In contrast, if you do it right the first time, there will be significant parts of code that never need to change, and the parts that do need to change will be much easier, because it will be obvious if it breaks the tests.

load more comments (8 replies)
[–] jplee 35 points 11 months ago (2 children)

Programming != Computer Science. Programming is just a tool used in computer science. Computer Science is so much more and follows scientific theory and methodology.

[–] [email protected] 12 points 11 months ago (1 children)

Computer programming is to computer science as telescope operation is to astronomy.

load more comments (1 replies)
load more comments (1 replies)
[–] [email protected] 35 points 11 months ago (1 children)

"Programming is just writing code"

Programming is, first and foremost, understanding what the fuck you want/need the computer to do. That means that some programmers (mostly analysts) may understand workflows and processes better than the people whose job depends on their knowledge of said things.

[–] [email protected] 12 points 11 months ago (8 children)

People don't realize that as you get better at programming, the amount of code you write goes down. At least in my experience, my work day has shifted to 80% thinking about what I'm going to write and then about 20% actually writing it.

load more comments (8 replies)
[–] BrianTheeBiscuiteer 35 points 11 months ago (12 children)

I've got a lot of these.

Programming is not doing leetcode problems all day long. Those problems can be a good brain exercise or a good prep for a [misguided] technical interview but in a real programming job you have next to no chance of running into problems like those. Even if you do, you're an idiot if you spend hours toiling away at a problem that somebody else already solved much more efficiently than you will. Your boss doesn't give a crap if you pulled all of the code straight from your brain.

Programmers are not hackers. The reverse might be true but hacking is about finding problems (and exploiting them) while programming is about fixing problems.

A programmer can do anything that involves code. Maybe not quite this succinct but I think most will assume you can write a mobile app or a website just because you say you can code. Websites, games, apps, and so on are written in code but they all involve different technologies, toolsets, and standards. I'm sure I could fumble my way through any kind of software but don't expect it done quickly if it's not my area of expertise.

[–] [email protected] 11 points 11 months ago

Especially regarding the first one: this seems like a very US-centric thing - or maybe a non-german thing. I've been in a bunch of interviews on both sides of the table here in Germany and I've literally never encountered a single leetcode question. At all.

load more comments (11 replies)
[–] [email protected] 34 points 11 months ago (7 children)

Requiring a candidate to know a specific programming language is stupid. Nearly all of the commonly used languages in industry are similar.

It's maybe more valuable to require knowledge in a specific framework, where knowledge is less transferrable between popular frameworks. Nonetheless, I personally rather hire an engineer that solves problems and learns flexibly rather than one that happens to know the right tech.

load more comments (7 replies)
[–] [email protected] 33 points 11 months ago (1 children)

Thar just because you solved a particular problem in 10min, all other problems are going to take 10min too.

[–] [email protected] 27 points 11 months ago (2 children)
[–] WalrusByte 22 points 11 months ago (1 children)

What's funny about this comic now is the second one has become very attainable in the years since it was released. The concept still applies though. Some things are a lot harder than they seem on the surface.

[–] [email protected] 25 points 11 months ago (1 children)

Somebody spent the money on a research team and five years is why it is very attainable now.

Someone trying to write the code from scratch would still take a research team and years to replicate it from scratch.

load more comments (1 replies)
[–] [email protected] 13 points 11 months ago

And here I was thinking of https://xkcd.com/664/

[–] [email protected] 32 points 11 months ago (12 children)

This one's a hot take, but: That Python is easy.

I've had to work with it in three projects in the past five years and I consider it one of the hardest programming languages, for anything but very short scripts.

You don't get proper compiler assistance, unless you have 100% test coverage. You don't get a helpful text editor. You don't usually get helpful type hints in libraries you use, so you have to genuinely just study the documentation and/or code. You get tons of quirky behavior in the stdlib, build tools, async stack, imports. You get breaking changes in minor versions of the language.

I find writing code in Python extremely mentally taxing, because you just get so little assistance, that you have to think of everything yourself.

[–] [email protected] 21 points 11 months ago (1 children)

Dynamically typed languages all suffer that fate. There's a reason Typescript literally has that feature in its name.

What does help though is type hinting. You "just" have to enforce it and its fallout in your entire codebase.

[–] [email protected] 12 points 11 months ago (1 children)

Yeah, we invested a lot of time into type hinting and checking, but mypy would never exit without warnings and errors, because many libraries we were using had no type hints.
It was also just exhausting/cumbersome, having to write type hints everywhere, as there's no type inference.

But yeah, we always joked that someone should create TypeScript for Python – Typhon.

load more comments (1 replies)
load more comments (11 replies)
[–] [email protected] 30 points 11 months ago* (last edited 11 months ago) (1 children)

Technical Leads are not rational beings and lots of software is developed from an emotional stand point.

Engineering is trade offs, every technical decision you make has a pro/con.

What you should do is write out the core requirements/constraints.Then you weigh the choices to select the option that best meets it.

What actually happens is someone really likes X framework, Y programming language or Z methodology and so decides the solution and then looks for reasons to justify it.

Currently the obvious tell is if they pitch Rust. I am not saying Rust is bad, but you'll notice they will extoll the memory safety or performance and forget about the actual requirements of the project.

[–] abhibeckert 26 points 11 months ago* (last edited 11 months ago) (2 children)

Currently the obvious tell is if they pitch Rust

I would amend that to "if they pitch any language".

The best language is almost universally "whatever we already use" or for new projects "whatever the team is most familiar with". It should occasionally be reconsidered, and definitely try out new languages, but actually switching to the new language after trying it out? That should be very very rare.

load more comments (2 replies)
[–] [email protected] 30 points 11 months ago* (last edited 11 months ago) (1 children)

If I can code doesn’t mean I know how to do X thing on your stupid phone

load more comments (1 replies)
[–] [email protected] 28 points 11 months ago

No programming language, development philosophy, or technology can save you from projects and business lacking clarity. Your ability to communicate and be understood is as/perhaps more important than the quality of your ideas. Consistency is better than perfection.

[–] stoly 27 points 11 months ago* (last edited 11 months ago) (5 children)

Honestly? The people who say "learn to code" as the solution to getting a better job. Only some people can do this.

Also the idea that tech "just works". Have had freshly-minted CS/info types suddenly realize why the phrase "back away slowly" exists.

load more comments (5 replies)
[–] [email protected] 24 points 11 months ago (2 children)

Some programmers are software engineers. They solve problems, sometimes problems with great ambiguity or non-straightforward solutions.

And some programmers are... code technicians? They understand and write code, but their job seldom involves problem solving. Often times, they're asked to code an already solved problem, or mostly solved.

This is not a diss. I was in the second camp for a while. But it hurts your career to stay in that. So be careful.

load more comments (2 replies)
[–] aluminium 22 points 11 months ago* (last edited 11 months ago) (4 children)

You NEED to be good be in math to program.

Whilest for some highly specialist fields you definitly do, but for a lot of jobs things don't get more complex than calculating averages.

[–] [email protected] 35 points 11 months ago (4 children)

OTOH, you need to be good at the same kinds of reasoning that leads one to be good at math. Not knowing much math isn't a problem, but not being able to learn math is probably a dealbreaker.

[–] [email protected] 12 points 11 months ago

I'm bad at math and struggled heavily through calc 2 and barely passed with a D+ but had little issue with data structures and algorithms (except when the algorithms were written in math notation, but still got through it after being explained in a logical set of steps instead).

load more comments (3 replies)
load more comments (3 replies)
[–] [email protected] 22 points 11 months ago (6 children)

This one might be a bit controversial, but has rung true in my general experience. Probably a lot of exceptions to these rules, but here goes:

You don't really know a programming language until you understand a fair amount of the standard library and how packages/modules/dependencies work. Syntax is pretty easy, and any mainstream language will work just fine for solving basic leet-code style problems. But when you really spend a lot of time working with a language, you're going to spend more time learning about common libraries and how to manage dependencies. If you're working with a language like C++ or Java, this could also include build systems and how to use them.

Another precursor to being able to say that you know a language is that you should also be familiar with best practices (ie. how to name modules, how to write documentation, etc.) and common pitfalls (undefined behavior, etc.). This is one of the hardest parts about learning a new language in my opinion, because the language may not necessarily enforce these things, but doing them the wrong way can make your life very difficult.

load more comments (6 replies)
[–] [email protected] 22 points 11 months ago (1 children)

The misconception that we’re the person to go to to fix your printer…

..I mean we probably can fix it, but it’s a waste of our time…

load more comments (1 replies)
[–] [email protected] 18 points 11 months ago (1 children)
[–] [email protected] 18 points 11 months ago (2 children)

Anyone can, but not everyone needs to

[–] [email protected] 18 points 11 months ago (1 children)
load more comments (1 replies)
load more comments (1 replies)
[–] hawgietonight 16 points 11 months ago* (last edited 11 months ago) (6 children)

Myth: code can be ugly as long as it works, don't spend company time on making it look good or on minor optimizations.

The truth is that you can tell when effort has been put into a job. Even if it just works, the lack of discipline means that in the end it will be difficult to maintain and probably will fail in unexpected situations.

Every language has its conventions, but if I spot more than a line of separation between blocks of code, that is a common telltale sign of noob. Run from that shit.

load more comments (6 replies)
[–] [email protected] 16 points 11 months ago (1 children)

Gamers demanding changes saying "it's literally one line of code"

load more comments (1 replies)
[–] [email protected] 15 points 11 months ago (1 children)

that doing more work, takes more time.

Gamers are especially guilty of this.

"that 2013 game runs at a smooth 60 fps. This medern game running at quadruple the resolution with raytracing sometimes dips to 58 fps on the same hardware. Devs must be lazy, they just need to add OPTIMIZATION to the game

load more comments (1 replies)
[–] [email protected] 13 points 11 months ago

When you release something, your work is not done. You have to maintain it, fix bugs, release patches, and probably the worst part, keeping it up to date.

For example, Apple decides to deprecate some API, or decides to switch cpu architecture, or for the millionth time change how app signing works, or add some new security feature that breaks your app. Now you need to make your app work properly on the new platform, switch APIs, all the fun. Or, there's some critical vulnerability in library you used and customers are deleting your app from their computers (a lot of companies use automated scanners that check against published CVEs). It's most fun when you learn that the new version that fixes the vulnerability completely breaks compatibility with the old one and now you have to rewrite all the code that used that library.

Also, maintaining open source projects is not fun. It's a lot of work, in most cases unpaid, thankless, and building a community around a project is really hard.

[–] [email protected] 12 points 11 months ago* (last edited 11 months ago)

That coding interviews are even by the tiniest measure good indicators of how capable a candidate is for a software engineering job.

I saw a great thread on Mastodon about this: link

[–] [email protected] 12 points 11 months ago (3 children)

People think computer as magic. That would be nice to make people understand that it's not. That's pretty much a dumb machine where we put our intelligence to work.

load more comments (3 replies)
load more comments
view more: next ›