My Authors
Read all threads
For all the (generally reasonable) advice to avoid linear-depth recursion in production code, I see little evidence that programmers at large know how to transform non-trivial recursive code into non-recursive stack-based code in a systematic way.
Aside from security/robustness concerns, it's also useful to transform push-based ("visitor") code to pull-based ("iterator") code. Even in languages with generators or coroutines, their overhead might be prohibitive.
And even though concerns about the cost of function calls are a bit old fashioned, if you have a piece of recursive code that's simple enough, you can sometimes get serious performance gains. There's an old example here: gist.github.com/pervognsen/a19…
Here's the generated machine code: gist.github.com/pervognsen/ce1…. It keeps almost everything in registers. The only memory traffic are to the explicit stack and the input string.
(I wouldn't necessarily recommend this particular approach since it's a little "out there", but you can do the moral equivalent of it in a more bare-handed way.)
Missing some Tweet in this thread? You can try to force a refresh.

Enjoying this thread?

Keep Current with Per Vognsen

Profile picture

Stay in touch and get notified when new unrolls are available from this author!

Read all threads

This Thread may be Removed Anytime!

Twitter may remove this content at anytime, convert it as a PDF, save and print for later use!

Try unrolling a thread yourself!

how to unroll video

1) Follow Thread Reader App on Twitter so you can easily mention us!

2) Go to a Twitter thread (series of Tweets by the same owner) and mention us with a keyword "unroll" @threadreaderapp unroll

You can practice here first or read more on our help page!

Follow Us on Twitter!

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just two indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3.00/month or $30.00/year) and get exclusive features!

Become Premium

Too expensive? Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal Become our Patreon

Thank you for your support!