378: Real Programmers

Explain xkcd: It's 'cause you're dumb.
Revision as of 22:12, 2 December 2012 by 82.212.178.63 (Talk)

Jump to: navigation, search
Real Programmers
Real programmers set the universal constants at the start such that the universe evolves to contain the disk with the data they want.
Title text: Real programmers set the universal constants at the start such that the universe evolves to contain the disk with the data they want.

Explanation

Ambox notice.png This explanation may be incomplete or incorrect:
Please include the reason why this explanation is incomplete, like this: {{incomplete|reason}}

If you can address this issue, please edit the page! Thanks.

This comic satirises the mythical Real Programmer. To quote Wikipedia, "the term Real Programmer is computer programmers' folklore to describe the archetypical "hardcore" programmer who eschews the modern languages and tools of the day in favour of more direct and efficient solutions". Gnu nano is a text editor - a program often used to edit the source code of other programs. Emacs, Vim and ed are all progressively more "hard core" editors. cat is a Unix program that concatenates and lists files. Things get steadily more ridiculous from here. Using a magnetised needle to flip bits on a hard drive requires nanometer-precision and binary mastery. The final character suggests the utterly surreal idea of using butterflies. Emacs is known for having a large number of add-ons to perform all sorts of functions beyond simple text editing. These commands are usually referred to by the key sequence required to activate them, such as "C-x M-c"(Control-x Meta/Esc/Alt-c, though this exact key sequence is a bit different from most Emacs commands and could be a joke or typo). The macro referenced is a pun on the play/movie titled "M. Butterfly". Later versions of Emacs actually added a "M-x butterfly" command as an easter-egg youtube demo, screenr demo.

To cap this the title text suggests manipulating the universal constants to get the required data onto the disk.

Transcript

[A man sits at a computer, programming. Another man behind him looks over his shoulder.]
Man: nano? REAL programmers use Emacs.
[A dark haired woman appears behind him.]
Woman: Hey. REAL programmers use Vim.
[Another man appears behind her.]
Man: Well, REAL programmers use ed.
[Another man appears behind him.]
Man: No, REAL programmers use cat.
[A woman with a bun appears behind him.]
Woman: REAL programmers use a magnetized needle and a steady hand.
[A man enters, facing them all.]
Man: Excuse me, but REAL programmers use butterflies.
[Holding out a butterfly in front of the computer.]
Man: They open their hands and let the delicate wings flap once.
Man: The disturbances ripple outward, changing the flow of the Eddy currents in the upper atmosphere.
[Diagrams of flowing currents.]
These cause momentary pockets of higher-pressure air to form, ...
Man: Which act as lenses that deflect incoming cosmic rays, focusing them to strike the drive platter and flip the desired bit.
Emacs User: Nice. 'Course, there's an Emacs command to do that.
Cat User: Oh yeah! Good ol' C-x M-c M-butterfly...
[Butterfly man slaps forehead.]
Butterfly man: Dammit, Emacs.
Comment.png add a comment!

Discussion

I was going to edit the above description, but it was taking too much time to edit it into a suitable format, so here's the long version.

In the beginning was UNIX. And it was good. And it was written by some very clever people.

One of the first very useful tools they wrote was ed, a "line-editor" (i.e. it works one line at a time). It uses some simple commands, and was created to work on very-old-school teletype machines, where you type a command, and ed types a response back.

It was a lovely bit of code. Using very little the way of resources, it allowed you to create a text document of any length, including source code in whatever language you wanted to program in.

Eventually, a more sophisticated version called ex (short for EXtended) was written by a clever man named Bill Joy. While it has some great improvements over ed, it was still a line-editor.

The trouble was, using a line-editor like ed or ex requires you to have a very good mental model of the document you are creating. Unfortunately, humans aren't very good at this, so they constantly need to refresh their mental model by printing out big chunks of the document (or program) they are working on. This took a LOT of paper using teletypes.

Eventually, teletypes were replaced with terminals. This saved a lot of paper. But the people who created the terminals began making them smarter than teletypes, so that magic character sequences could be used to move the cursor around, rather that simply going character-by-character across the line, then scrolling down to the next line, and so on. This opened up a whole new world.

The very clever Bill Joy took advantage of these magic character sequences to create his wonderful "full-screen" text editor vi. vi was the "VIsual mode" of ex. With vi, the user could see a screen-full of text at once. Entire forests were saved.

Emacs was developed at the same time as vi, using the same magic characters, and was also a full-screen text editor. I've never used it, so I can't speak to its merits, but there are many people who still find it more useful than any GUI they've tried.

On the one hand, vi and emacs are more sophisticated tools, and thus take longer to learn to use than ed. However, once you learn to use them, they make writing code EASIER, and they are therefore considered a less praise-worthy way of writing code by those concerned with defining what a "Real Programmer" is. (In other words, those programmers suffering from testosterone poisoning.)

Using cat to write a program looks like this: (Note that the $ is the prompt provided by the computer. The rest is typed by the user. And the ^D means the user held down the control key while typing the letter "d".)

$ cat | cc
The user types C code here, and ends with ^D. Assuming all goes well, the compiler silently finishes after creating the executable program a.out in the user's current working directory.

The reason this is considered a more praise-worthy way of coding is that, in those early days, doing this meant that your code was lost the instant you typed it. If you made a mistake, you would have to type the whole thing again. So doing this for code of any sophistication was considered an act of courage, confidence, and conviction. (I myself did it several times, for the fun of it, when no-one was watching, though never for a program that took more than about 30 lines of code. I was delighted that it worked all 3 times, but since I love to write re-usable code, this wasn't really something I wanted to keep doing.)

NOW PAY ATTENTION. VI IS NOT VIM! Vim was written in 1991, long after more sophisticated shells were created that made it possible to copy and paste text from one part of the screen to another. This ability greatly reduced the risks of using cat to pass your source code directly to the compiler, so it was no longer a praise-worthy stunt. Thus the line "Real programmers use vim" was NEVER considered true by any UNIX programmer.

Whether this was a mistake of the author, or the character (possibly Megan?) is unclear. It seems possible that it was a simple typo, but since I've never seen one in the strip before, I'm somewhat skeptical.

--MisterSpike (talk) 07:12, 17 June 2013 (UTC)

cat | cc doesn't work on my system. My cc is simply a symlink to gcc; what's yours? --Lucaswerkmeister (talk) 10:16, 7 August 2013 (UTC)
One can also use
$ cat | gcc -xc -
The program will be an a.out file. 200.131.199.28 (talk) (please sign your comments with ~~~~)

Some comments:

I would never claim to be an emacs expert, but I'm reasonably proficient in it. Command of the form M-x (whatever) are a way of calling commands (or, really, arbitrary functions in the emacs code) by name. SO 'M-x butterfly' means that there is a function named "butterfly" somewhere, but that it has not been assigned a keyboard shortcut (or it has, but you're calling it the long way).

Also, three are still advanced Linux programmers today who swear by vim or emacs being superior to IDEs. There are specific technical reasons for this: emacs is basically an IDE construction kit that's incredibly easy to extend and customize, and is more customizable than pretty much any other program in the history of software with the exception of a Smalltalk installation. And vim has highly evolved commands to give experts a superhuman typing and editing speed when coding.

So when someone claims that "real programmers use vim," they are claiming that RIGHT NOW, vim is the best possible editor for developers of sufficient competence. There's a community of very smart people that basically thinks this.

Tess (talk) 04:19, 15 December 2013 (UTC)


Personal tools
Namespaces

Variants
Actions
Navigation
Toolbox

It seems you are using noscript, which is stopping our project wonderful ads from working. Explain xkcd uses ads to pay for bandwidth, and we manually approve all our advertisers, and our ads are restricted to unobtrusive images and slow animated GIFs. If you found this site helpful, please consider whitelisting us.

Want to advertise with us, or donate to us with Paypal or Bitcoin?