Conditional loop

In computer programming, conditional loops or repetitive control structures are a way for computer programs to repeat one or more various steps depending on conditions set either by the programmer initially or real-time by the actual program.

A conditional loop has the potential to become an infinite loop when nothing in the loop's body can affect the outcome of the loop's conditional statement. However, infinite loops can sometimes be used purposely, often with an exit from the loop built into the loop implementation for every computer language, but many share the same basic structure and/or concept. The While loop and the For loop are the two most common types of conditional loops in most programming languages.

Types

The following types are written in Java, but apply to multiple languages.

While loop

Checks condition for truthfulness before executing any of the code in the loop. If condition is initially false, the code inside the loop will never be executed. In PL/I this is a DO WHILE... statement.

 while ( condition )
 {
   /* code */
 }

Do-While loop

Checks condition for truthfulness after executing the code in the loop. Therefore, the code inside the loop will always be executed at least once. PL/I implements this as a DO UNTIL... statement.

 do
 {
   /* code */
 } while ( condition );

For loop

A simplified way to create a while loop.

 /* for a real example of what a, b, or c might be, see example below */
 for ( a; b; c )
 {
   /* code */
 }

a is executed just once before the loop. b is the condition of the loop. c is executed at the end of every loop.

So for example, the following while loop:

 int i = 0;
 while ( i < 10 )
 {
   /* code */
   i++;
 }

Could be written as the following for loop:

 for ( int i = 0; i < 10; i++ )
 {
   /* code */
 }

For-Each Loop

A for-each loop is essentially equivalent to an iterator. It allows a program to iterate through a data structure without having to keep track of an index. It is especially useful in Sets which do not have indices. An example is as follows:

 Set<Object> theSet = new HashSet<Object>();
 /* initialize values in theSet */
 for(Object obj : theSet)
 {
    /* code */
 }

Examples

The following is a C-style While loop. It continues looping while x does not equal 3, or in other words it only stops looping when x equals 3. However, since x is initialized to 0 and the value of x is never changed in the loop, the loop will never end (infinite loop).

 int x = 0;
 while ( x != 3 )
 {
   /* code that doesn't change x */
 }

The while loop below will execute the code in the loop 5 times. x is initialized to 0, and each time in the loop the value of x is incremented. The while loop is set up to stop when x is equal to 5.

 int x = 0;
 while ( x != 5 )
 {
   /* code here */
   x = x + 1;
 }

Frequent bugs

Conditional loops are often the source of an Off by one error.

This article is issued from Wikipedia - version of the 10/5/2016. The text is available under the Creative Commons Attribution/Share Alike but additional terms may apply for the media files.