C/C++ C++ Infinite Loops: Why Do They Occur?

AI Thread Summary
Infinite loops occur when the continuation condition of a loop remains true indefinitely, preventing the loop from terminating. This can happen for several reasons, including skipping the conditional statement, failing to reach a break condition, or waiting for an event that never occurs. For example, a loop that increments a variable incorrectly may never meet its termination condition, while a loop designed to wait for a client connection may run indefinitely if the connection never happens. Additionally, some loops are intentionally infinite, such as those used in animations or games, where continuous execution is necessary. Programmers must ensure that their loops have precise conditions to avoid unintended infinite loops, as these can lead to performance issues or application crashes. Understanding the mechanics of loop constructs is critical for effective programming.
ineedhelpnow
Messages
649
Reaction score
0
why do infinite loops occur? is it just because the condition is always true?
 
Technology news on Phys.org
Well, yes. Otherwise.. the loop would terminate.

...
 
that's the only reason? because my teacher was all like "make sure you understand infinite loops! it's very critical that you understand why they happen!"...(Dull)
 
ineedhelpnow said:
that's the only reason? because my teacher was all like "make sure you understand infinite loops! it's very critical that you understand why they happen!"...(Dull)

What other reason could there be? Every loop construct repeats for as long as its termination condition is false, or, equivalently, the continuation condition is true (the converse is not true because you can break out of a loop early with e.g. "break" or even "goto", but you cannot "continue" a loop if the continuation condition has become false - well, you could goto back to the start, but that's abusing the loop construct).

Now an infinite loop occurs if and only if it never terminates, that is, always continues, which is thus logically equivalent to the continuation condition always remaining true. There is no other possibility.



That said, in a less abstract sense, some people refer to as "infinite loops" any construct of the form:

Code:
while (true)
{
    /* do some work here */

    if (condition1)
        break;

    /* more work */

    if (condition2)
        break;

    /* etc. */
}

That is, it's not really infinite, but it looks infinite, and it let's the programmer run a loop for an arbitrary amount of time with more flexibility than a single termination condition offers. Those are especially common in parsing code for some grammars and other state-machine-style algorithms.
 
It is always the programmer work to avoid infinite loops. You have to make the condition as precise as possible so that you are not stuck. If the algorithm requires a finite number of steps you have to make sure that it terminates. An infinite loop can occur for many reasons :

1. You skip the conditional statement by incrementing more than one

Code:
i=0;
while ( i != 9)
     doSomething();
     i+=2;
end while

As we see from the example the i's are even so the conditional statement will never occur.

2. The break never occurs

Sometimes you don't know what are the maximum number of iterations to terminate. Fore example

Code:
while(true)
   x = approximateRoot();
   if(abs(x-root) < 1e-n)
      break;
   end if
end while

As we see from the example the loop approximates the root of a certain function and compares with the real root. If the absolute error is small enough we terminate. But what happens if the function to approximate the root never gets close to the real root. The loop will never terminate because the sequence will diverge.

3. Waiting for something that never happens

Especially in internet related applications you create a socket to listen to a port waiting for a certain port to wait for clients.

Code:
while(true)
   int flag = listenPort( portNumber);
   if(flag == 1)
      break;
   end if;
end while

The loop runs for an undetermined number of iterations and waits for the client to connect then breaks. Hence that provides a useful application.

4. Loops that never terminate upon execution

Sometimes you want a loop that always runs until we close the application.

Code:
//moving a ball in a coordinate 
while(true)
   paintBall(++x , ++y);
   Thread.Sleep (Time.milliseconds);
end while

Infinite loops are great when creating animations and games. A continuously running thread to handle a certain animating object will run upon executing the program. The ball will move for a certain number of pixels then waits for a certain time , after that it continues moving. This gives impression of the ball moving smoothly.
 
ZaidAlyafey said:
It is always the programmer work to avoid infinite loops. You have to make the condition as precise as possible so that you are not stuck. If the algorithm requires a finite number of steps you have to make sure that it terminates. An infinite loop can occur for many reasons :

1. You skip the conditional statement by incrementing more than one

Code:
i=0;
while ( i != 9)
     doSomething();
     i+=2;
end while

As we see from the example the i's are even so the conditional statement will never occur.

2. The break never occurs

Sometimes you don't know what are the maximum number of iterations to terminate. Fore example

Code:
while(true)
   x = approximateRoot();
   if(abs(x-root) < 1e-n)
      break;
   end if
end while

As we see from the example the loop approximates the root of a certain function and compares with the real root. If the absolute error is small enough we terminate. But what happens if the function to approximate the root never gets close to the real root. The loop will never terminate because the sequence will diverge.

3. Waiting for something that never happens

Especially in internet related applications you create a socket to listen to a port waiting for a certain port to wait for clients.

Code:
while(true)
   int flag = listenPort( portNumber);
   if(flag == 1)
      break;
   end if;
end while

The loop runs for an undetermined number of iterations and waits for the client to connect then breaks. Hence that provides a useful application.

4. Loops that never terminate upon execution

Sometimes you want a loop that always runs until we close the application.

Code:
//moving a ball in a coordinate 
while(true)
   paintBall(++x , ++y);
   Thread.Sleep (Time.milliseconds);
end while

Infinite loops are great when creating animations and games. A continuously running thread to handle a certain animating object will run upon executing the program. The ball will move for a certain number of pixels then waits for a certain time , after that it continues moving. This gives impression of the ball moving smoothly.

makes sense. if i could thank this post a million times, i would. although i haven't got to the 'i' stuff in my homework yet, i get what you're saying. (Bigsmile)
 
Dear Peeps I have posted a few questions about programing on this sectio of the PF forum. I want to ask you veterans how you folks learn program in assembly and about computer architecture for the x86 family. In addition to finish learning C, I am also reading the book From bits to Gates to C and Beyond. In the book, it uses the mini LC3 assembly language. I also have books on assembly programming and computer architecture. The few famous ones i have are Computer Organization and...
I had a Microsoft Technical interview this past Friday, the question I was asked was this : How do you find the middle value for a dataset that is too big to fit in RAM? I was not able to figure this out during the interview, but I have been look in this all weekend and I read something online that said it can be done at O(N) using something called the counting sort histogram algorithm ( I did not learn that in my advanced data structures and algorithms class). I have watched some youtube...

Similar threads

Back
Top