this post was submitted on 06 Jul 2024
1537 points (99.4% liked)

Programmer Humor

20118 readers
1552 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 6 points 6 months ago (4 children)

How bad programmers comment their code. Good programmers don't comment at all and let the code speak for itself, leaving commenting to some obscure and arcane implementation the coder left in after a week long binge on caffeine and gummy bears.

[–] [email protected] 11 points 6 months ago* (last edited 6 months ago) (2 children)

Code should absolutely speak for itself. But the occasional comment is still good to explain the 'why' of the code when the why isn't very obvious, often due to a niche requirement. Also any time you have to break out a hack, that needs comments up the ass, what was the bug, what URL did you find the fix at, why does this hack work, etc etc. It's very satisfying to go back and remove those hacks after they are no longer needed, often because the underlying technology fixed the bug that had to be hacked around.

[–] [email protected] 2 points 6 months ago* (last edited 6 months ago)

It definitely feels great when I get to remove the

//hack abc due to bug in library xyz version 1.4.5, issue tracker says it's fixed in 1.5.0. - link

[–] [email protected] 2 points 6 months ago

Yeah, hence me mentioning the arcane code nobody knows what it does.

[–] [email protected] 17 points 6 months ago (1 children)

"What does this section of code do?"

Run it and find out, coward.

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

Nah. It should be obvious by just looking at it in code. If it isn't, you haven't extracted single purpose methods out of it yet.

[–] [email protected] 2 points 6 months ago* (last edited 6 months ago)

Just having clear and concise variable names often goes a long way. Avoid using abbreviations.

Breaking out the code into functions helps limit the number of variables within a scope, which makes it easier to name them.

[–] [email protected] 6 points 6 months ago* (last edited 6 months ago) (1 children)

This is the truth. In my experience, the people who often writes comments are also writing the most incomprehensible code.

Comments are frequently getting outdated as well, so they’re not in great help understanding the code either.

[–] [email protected] 4 points 6 months ago

I was rewriting some old code of mine and ended up stripping out the comments. I kept reading them instead of the code, which I had been changing, and they were irrelevant. (I added new comments back in, though a big reason to rewrite was to make the code more self-explanatory.)