Functional Programming - Lots of emphasis on recursion, why?
Posted
by
peakit
on Stack Overflow
See other posts from Stack Overflow
or by peakit
Published on 2012-09-30T07:42:17Z
Indexed on
2012/09/30
15:37 UTC
Read the original article
Hit count: 416
I am getting introduced to Functional Programming [FP] (using Scala). One thing that is coming out from my initial learnings is that FPs rely heavily on recursion. And also it seems like, in pure FPs the only way to do iterative stuff is by writing recursive functions.
And because of the heavy usage of recursion seems the next thing that FPs had to worry about were StackoverflowExceptions
typically due to long winding recursive calls. This was tackled by introducing some optimizations (tail recursion related optimizations in maintenance of stackframes and @tailrec
annotation from Scala v2.8 onwards)
Can someone please enlighten me why recursion is so important to functional programming paradigm? Is there something in the specifications of functional programming languages which gets "violated" if we do stuff iteratively? If yes, then I am keen to know that as well.
PS: Note that I am newbie to functional programming so feel free to point me to existing resources if they explain/answer my question. Also I do understand that Scala in particular provides support for doing iterative stuff as well.
© Stack Overflow or respective owner