aboutsummaryrefslogtreecommitdiff
path: root/src/content/chapter2_flow_control/lesson06_tail_calls/text.html
diff options
context:
space:
mode:
authorLouis Pilfold <louis@lpil.uk>2024-01-18 20:34:43 +0000
committerLouis Pilfold <louis@lpil.uk>2024-01-18 20:34:43 +0000
commitab2b9a982ede817362072623ff9ae2aa42e083da (patch)
tree5c055c588fafc5075831b7d9273e232da76da73b /src/content/chapter2_flow_control/lesson06_tail_calls/text.html
parent8d93f5ab2a04a9f2f8eb23b11617d83fad1c5316 (diff)
downloadtour-ab2b9a982ede817362072623ff9ae2aa42e083da.tar.gz
tour-ab2b9a982ede817362072623ff9ae2aa42e083da.zip
Move recursion lessons together
Diffstat (limited to 'src/content/chapter2_flow_control/lesson06_tail_calls/text.html')
-rw-r--r--src/content/chapter2_flow_control/lesson06_tail_calls/text.html23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/content/chapter2_flow_control/lesson06_tail_calls/text.html b/src/content/chapter2_flow_control/lesson06_tail_calls/text.html
new file mode 100644
index 0000000..ec39cda
--- /dev/null
+++ b/src/content/chapter2_flow_control/lesson06_tail_calls/text.html
@@ -0,0 +1,23 @@
+<p>
+ When a function is called a new stack frame is created in memory to store the
+ arguments and local variables of the function. If lots of these frames are
+ created during recursion then the program would use a large amount of memory,
+ or even crash the program if some limit is hit.
+</p>
+<p>
+ To avoid this problem Gleam supports <em>tail call optimisation</em>, which
+ allows the compiler to reuse the stack frame for the current function if a
+ function call is the last thing the function does, removing the memory cost.
+</p>
+
+<p>
+ Unoptimised recursive functions can often be rewritten into tail call
+ optimised functions by using an accumulator. An accumulator is a variable that
+ is passed along in addition to the data, similar to a mutable variable in a
+ language with <code>while</code> loops.
+</p>
+<p>
+ Accumulators should be hidden away from the users of your code, they are
+ internal implementation details. To do this write a public function that calls
+ a recursive private function with the initial accumulator value.
+</p>