Programming idiom

From Wikipedia, the free encyclopedia

A programming idiom is a means of expressing a recurring construct in one or more programming languages. Generally speaking, a programming idiom is an expression of a simple task or algorithm that is not a built-in feature in the programming language being used, or, conversely, the use of an unusual or notable feature that is built in to a programming language. The term can be used more broadly, however, to refer to complex algorithms or programming design patterns.

Knowing the idioms associated with a programming language and how to use them is an important part of gaining fluency in that language.

Contents

[edit] Examples of Simple Idioms

[edit] Incrementing a counter

In a language like Basic, the code to increment a counter by one is mundane:

 i = i + 1

The C programming language and many others derived from it have language-specific features that make this code shorter:

 i += 1; /* i = i + 1; */
 i++;    /* same       */

Pascal, as a keyword centric language, contains a built in procedure for the same operation:

 i := i + 1;
 Inc(i); (* same *)

These are the idiomatic ways of "adding one to a counter".

[edit] Swapping values between variables

In many languages, code for swapping the values in two variables looks like the following:

 temp = a;
 a = b;
 b = temp;

In Perl, the list assignment syntax allows a more succinct expression:

 ($a, $b) = ($b, $a);

[edit] Infinite loop

The code used to write an infinite (nonterminating) loop varies widely between different programming languages, although it often takes the form of a while loop where the test condition is always true. In Pascal, for example:

 while true do begin
   do_something();
 end;

There are several ways to write an infinite loop in C, including a loop very similar to the Pascal example, but the following idiom uses the unusual appearance of the empty for loop condition to draw attention visually to the loop:

 for (;;) {
   do_something();
 }

Perl allows the C syntax above, but supports some other syntax as well. For example:

 do_something() while (1);  # Succinct one-line infinite loop
 
 # Using a "naked block" and the redo operator
 {
   do_something();
   redo;
 }