Skip to Content
Learning Functional Programming in Go
book

Learning Functional Programming in Go

by Lex Sheehan
November 2017
Intermediate to advanced
670 pages
17h 35m
English
Packt Publishing
Content preview from Learning Functional Programming in Go

Non-TCO recursive example

First, we'll look at the imperative example:

rSum :: [Integer] -> IntegerrSum (x:xs) = x + (rSum xs)rSum [] = 0

Note that x:xs means we store the head of the list in x and the rest of the list is in xs.

Our goal: To recursively sum the numbers in the list [1, 2, 3].

Each call to rSum needs to get the return value of the recursive call and add it to its x parameter before it can return. This means that each function must stay on the stack longer than the frame of any function that it calls. We had to create four stack frames to sum three numbers. Imagine the amount of RAM storage that this implementation will require ...

Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Start your free trial

You might also like

Learning Functional Programming

Learning Functional Programming

Jack Widman

Publisher Resources

ISBN: 9781787281394Supplemental Content