Anonymous recursion

From Rosetta Code
Revision as of 17:13, 23 November 2010 by rosettacode>Abu (Created as draft)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Anonymous recursion is a draft programming task. It is not yet considered ready to be promoted as a complete task, for reasons that should be found in its talk page.

While implementing a recursive function, it often happens that we must resort to a separate "helper function" to handle the actual recursion.

This is usually the case when directly calling the current function would waste too many resources (stack space, execution time), cause unwanted side-effects, and/or the function doesn't have the right arguments and/and return values.

So we end up inventing some silly name like "foo2" or "foo_helper". I have always found it painful to come up with a proper name, and see a quite some disadvantages:

  • You have to think up a name, which then pollutes the namespace
  • A function is created which is called from nowhere else
  • The program flow in the source code is interrupted

Some languages allow you to embed recursion directly in-place. This might work via a label, a local gosub instruction, or some special keyword.

If possible, demonstrate this by writing the recursive version of the fibonacci function (see Fibonacci sequence) which checks for a negative argument before doing the actual recursion.