Book Image

Hands-On Functional Programming with C++

By : Alexandru Bolboaca
Book Image

Hands-On Functional Programming with C++

By: Alexandru Bolboaca

Overview of this book

Functional programming enables you to divide your software into smaller, reusable components that are easy to write, debug, and maintain. Combined with the power of C++, you can develop scalable and functional applications for modern software requirements. This book will help you discover the functional features in C++ 17 and C++ 20 to build enterprise-level applications. Starting with the fundamental building blocks of functional programming and how to use them in C++, you’ll explore functions, currying, and lambdas. As you advance, you’ll learn how to improve cohesion and delve into test-driven development, which will enable you in designing better software. In addition to this, the book covers architectural patterns such as event sourcing to help you get to grips with the importance of immutability for data storage. You’ll even understand how to “think in functions” and implement design patterns in a functional way. By the end of this book, you’ll be able to write faster and cleaner production code in C++ with the help of functional programming.
Table of Contents (23 chapters)
Free Chapter
1
Section 1: Functional Building Blocks in C++
7
Section 2: Design with Functions
12
Section 3: Reaping the Benefits of Functional Programming
17
Section 4: The Present and Future of Functional Programming in C++

<optional> and <variant>

We have discussed happy path cases a lot, which are when the data is valid for our data transformations. What do we do for edge cases and errors? Sure, in exceptional cases, we can throw exceptions or return error cases, but what about situations when we need to return an error message?

The functional way is to return data structures in these cases. After all, we need to return an output value even when the input isn't valid. But we hit a challenge—the type we need to return in the case of an error is an error type, while the type we need to return in the case of valid data is some more valid data.

Fortunately, we have two structures that support us in these cases—std::optional and std::variant. Let's take an example of a list of people, some of whom are valid and some of whom are invalid:

    vector<Person> people...