Very Deep or Infinite Recursion
The most common cause of stack overflow is excessively deep or infinite recursion. Languages like Scheme, which implement tail-call optimization, allow infinite recursion of a specific sort—tail recursion—to occur without stack overflow. This works because tail-recursion calls do not take up additional stack space.
An example of infinite recursion in C.
int foo { return foo; }The function foo, when it is invoked, continues to invoke itself, using additional space on the stack each time, until the stack overflows resulting in a segmentation fault.
Read more about this topic: Stack Overflow
Famous quotes containing the words deep and/or infinite:
“In loves deep womb our fears are held;
there Gods rich tears are sown
and bring to birth, in hope new-born,
the strength to journey on.”
—Rob Johns (20th century)
“This is the monstruosity in love, ladythat the will is infinite and the execution confined; that the desire is boundless and the act a slave to limit.”
—William Shakespeare (15641616)