Skip to Content
Learning Functional Programming
book

Learning Functional Programming

by Jack Widman
August 2022
Intermediate to advanced
135 pages
2h 51m
English
O'Reilly Media, Inc.
Book available
Content preview from Learning Functional Programming

Chapter 4. Functional Data Structures

Data structures are a foundational concept in computer science. Along with algorithms, they are a staple of what a computer science student or programmer must master. As with the phrase functional pattern, functional data structure is not an established concept with a consistent definition in the canon of code.

In this book, I will refer to two things as functional data structures.

  • Structures used in functional patterns, such as Option, Either, Try, List. These are monads.

  • Ordinary data structures that are implemented in a functional way so that they don’t mutate state, such as a linked list.

In this chapter, we will treat the first kind of functional data structures and then briefly cover some of the ideas surrounding ordinary data structures implemented in a functional way. Before we look at particular data structures, let me mention an idea about functional data structures that has been discussed in the literature. First, there is this quote from Alan Perlis:

It is better to have 100 functions operate on one data structure than to have 10 functions operate on 10 data structures.

Seasoned functional programmers tend to use a small set of data structures: linked lists, arrays, and hash tables, as well as structures such as Option, Either, and Try, to name a few. We will examine these next. I believe the idea behind this quote is that fewer data structures results in more uniformity and simplicity in the codebase. Now, let’s look at ...

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

Mastering Functional Programming

Mastering Functional Programming

Anatolii Kmetiuk

Publisher Resources

ISBN: 9781098111748Errata Page