|
|
|
|
|
by smt88
3896 days ago
|
|
> My point is: until readability is formally defined and we're able to measure it objectively it's utterly useless to talk about it. It's more defined than we, as programmers, pretend it is. There's research in cognitive psychology, linguistics, and lexicology that tells us that some things are easier for human brains to process than others. For example, if you skim through a block of code, it's easier to pick out "&&" than it is to pick out "and". There are lots of rules like this. This is partially because of the way humans read words. If yuo spel a bunhc of words wrng in a sentence in minor ways that don't alter the shapes too much, it's still very readable. That's why your example of J is very hard to read (objectively, not relatively). If someone removed or altered a few of those symbols, no one would notice upon skimming it. It's ludicrous to argue that it's readable just because some people say it is (and I think they're just bragging to begin with). |
|
I'm not convinced that such research controls for familiarity effects. Not to mention, programming languages have much richer syntaxes than natural languages. I think (suspect), in regard to PLs, what you're talking about (you mention "skimming" later) is actually legibility - ease of recognizing letters and words. Not readability, that is ease of understanding the meaning of what's written.
> For example, if you skim through a block of code, it's easier to pick out "&&" than it is to pick out "and".
Why? What if the rest of the line is similarly composed of punctuation? Are you sure in a line looking like this:
you'd have an easier time spotting the "and" were it written as "&&": > If someone removed or altered a few of those symbols, no one would notice upon skimming it.Possibly, but we're not talking about "skimmability", but readability. Removing or altering a few characters in that line would result in an incorrect, nonsensical sentence and you'd notice it right away.
"Right away" is subjective, of course. I spent nearly an hour trying to read this damned thing when I attempted it for the first time. Every J phrase was a challenge then. It's still hard, but it got much easier with practice. The trick here is exactly the same as in your example:
> yuo spel a bunhc of words wrng
that is, once you learn how the words look like you can recognize them easily, even if they are a bit mangled.
> (and I think they're just bragging to begin with)
Yeah, I get the same feeling sometimes ;-)
But a human brain is great at pattern recognition. It has to be trained, and it's possible that some shapes are harder to learn to recognize than others, but once you learned them... is there really a difference?
Learning different PLs is my hobby, I've looked at ~80 languages to date and learned quite a chunk of them. Every single time I noticed this effect: once you internalize shapes of common phrases, you stop having trouble reading the code. It's much, much harder in some case (J is an abomination here - I'm trying to really learn it for the second year now and... it's not going that well) and easier in others (Smalltalk, Lisp, Forth, ...). But I strongly suspect every language, if studied and used enough, becomes readable.