Ousterhout also recently had a lively debate with Robert
C Martin, another popular author of programming books,
which is somewhat illuminating. One may read the exchange
here: https://github.com/johnousterhout/aposd-vs-clean-code/blob/main/README.md
Thanks for sharing, interesting discussion recorded over there.
I'll grab the book. I have and read Clean Code.
Great. I must confess, however; at this point, I despise
"Clean Code". It's bad advice, and my opinion is that Robert
Martin is a blowhard and a charlatan. He's just not a very
good programmer.
"Clean Code". It's bad advice, and my opinion is that Robert
Martin is a blowhard and a charlatan. He's just not a very
good programmer.
Come on, tenser - stop beating around the bush and tell us what you
really think :)
"Clean Code". It's bad advice, and my opinion is that Robert Martin is a blowhard and a charlatan. He's just not a very
good programmer.
Come on, tenser - stop beating around the bush and tell us what you really think :)
Well, in fairness, I don't think he kicks puppies or anything. :-)
"Clean Code". It's bad advice, and my opinion is that Robert Martin is a blowhard and a charlatan. He's just not a very good programmer.
Come on, tenser - stop beating around the bush and tell us what really think :)
Well, in fairness, I don't think he kicks puppies or anything. :-)
Perhaps there's already something later, but I was hoping there'd be something describing why it's bad advice.
The rest of it I don't particularly care about, since there are plenty of blowhards, charlatans, and bad programmers.
And, heck, most of us probably do those things to some extent from time
to time regardless.
Anyway, I haven't read Clean Code, but I'm very pro commenting. Yes,
there are such things as too much commenting, but aside from in school when people were commenting, "//adds 1 to x", it's not something I've
ever seen.
But random blocks of code where I'm supposed to just _know_ what the
heck the previous programmer was supposed to mean, based off of
variables? Yeah, those I've seen plenty of.
Especially when it's something where I don't understand the code base,
and I'm looking for _anything_ to help me to latch on what's going on in
a certain section.
Great. I must confess, however; at this point, I despise
"Clean Code". It's bad advice, and my opinion is that Robert
Martin is a blowhard and a charlatan. He's just not a very
good programmer.
One of John Ousterhout's criticisms of Martin is that he doesn't
balance his advice: he goes to an extreme, so far as to call
comments failures, but doesn't discuss when they may be necessary.
The advice is thus not usefully weighted in situations where
things are ambiguous.
Others can probably say it better than I can. Something like https://qntm.org/clean is a good reference.
Then you probably wouldn't like "Clean Code." :-) Martin describes
a comment as a "failure".
I certainly think that there are times when a better name or a
temporary variable or something can make a comment completely
redundant, and that's good, but he goes entirely too far.
comments failures, but doesn't discuss when they may be necessary.
The advice is thus not usefully weighted in situations where
things are ambiguous.
names like, `isLeastRelevantMultipleOfLargerPrimeFactor`. Yeah, I
don't know what the hell that means, either, and I'm positive that
This is the thing that clinches it for me. Martin's advice is all extremely tactical: "here's how you should write this (class|function)." It doesn't help with building larger systems at all.
But even after things are pretty tight, I _still_ want the comments in there, because it'll explain what was in my head as I wrote the code, and give me a chance of explaining the code in a second way that might make more sense to the next person to come by.
Obviously, I'll try to use good variable names, have easy-to-follow code, and so on, but even with perfect code, it's a guarantee that all but the simplest situations will have people with a different mindset coming through and wondering what the heck was going on.
Great. I must confess, however; at this point, I despise
"Clean Code". It's bad advice, and my opinion is that Robert
Martin is a blowhard and a charlatan. He's just not a very
good programmer.
Sysop: | digital man |
---|---|
Location: | Riverside County, California |
Users: | 1,024 |
Nodes: | 17 (1 / 16) |
Uptime: | 00:47:15 |
Calls: | 503,341 |
Calls today: | 10 |
Files: | 107,019 |
D/L today: |
28,054 files (1,919M bytes) |
Messages: | 441,528 |
Posted today: | 4 |