Trampolines and thunks

For the last solution to our problem, we shall have to think about the cause of the problem. Each pending recursive call creates a new entry stack. Whenever the stack gets too empty, the program crashes and our algorithm is history. So, if we can work out a way to avoid the stack growth, we should be free. The solution, in this case, is quite imposing and requires thunks and a trampoline—let's see what these are!

First, a thunk is really quite simple: it's just a nullary function (so, with no parameters) that helps delay a computation, providing a form of lazy evaluation. If you have a thunk, then, unless you call it, you won't get its value. For example, if you want to get the current date and time in ISO format, you ...

Get Mastering JavaScript Functional Programming - Second Edition now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.