Functional Programming Patterns in Scala and Clojure
Write Lean Programs for the JVM
by: Michael Bevilacqua-Linn
Published | 2013-11-10 |
---|---|
Internal code | mbfpp |
Print status | In Print |
Pages | 256 |
User level | Advanced |
Keywords | scala, clojure, jvm, functional programming, patterns, REPL, OO, |
Related titles | Programming Scala |
ISBN | 9781937785475 |
Other ISBN |
Channel epub: 9781680503562 Channel PDF: 9781680503579 Kindle: 9781937785857 Safari: 9781941222416 Kindle: 9781937785857 |
BISACs | COM051300 COMPUTERS / Programming / AlgorithmsCOM051010 COMPUTERS / Programming Languages / GeneralCOM051010 COMPUTERS / Programming Languages / General |
Highlight
Solve real-life programming problems with a fraction of the code that pure object-oriented programming requires. Use Scala and Clojure to solve in-depth problems and see how familiar object-oriented patterns can become more concise with functional programming and patterns. Your code will be more declarative, with fewer bugs and lower maintenance costs.
Description
Functional languages have their own patterns that enable you to solve problems with less code than object-oriented programming alone. This book introduces you, the experienced Java programmer, to Scala and Clojure: practical, production-quality languages that run on the JVM and interoperate with existing Java. By using both the statically typed, type-inferred Scala and the dynamically typed, modern Lisp Clojure, you’ll gain a broad understanding of functional programming.
For each pattern, you’ll first see the traditional object-oriented solution, and then dig into the functional replacements in both Scala and Clojure. These patterns are common in the functional world and deserve to become part of your problem-solving toolkit. On the object-oriented side, you’ll see many common patterns, such as Command, Strategy, and Null Object. On the functional side, you’ll learn core functional patterns such as Memoization, Lazy Sequence, and Tail Recursion.
Each pattern helps you solve a common programming problem. Working through them gives you a set of patterns you can use to solve problems you come across while writing programs. Finally, you’ll learn how to work your existing Java code into new Scala or Clojure projects. You can start off small, adding functional code little by little, so you can complement your existing knowledge with Scala and Clojure as these languages gain popularity on the JVM.
Q&A with Michael Bevilacqua-Linn, author of Functional Programming Patterns in Scala and Clojure
Why did you write Functional Programming Patterns?
Languages with a functional flavor are getting more and more mainstream, and I wanted to write something that would help folks with a lot of traditional OO pattern knowledge start to make the transition.
I don’t know Scala or Clojure. How hard would it be for me to understand the examples in the book?
This book is written for programmers who are new to Scala and Clojure, but who have significant experience with Java and object-oriented patterns. One of its goals is to help ease experienced object-oriented programmers into a more functional style.
What can I do with functional patterns I couldn’t do before?
It’s not so much what you can do, as what you can do better! Functional programming, and the patterns that go along with it, tends to be more declarative than imperative programming, so you can solve problems with code that’s both more straightforward and shorter. The functional focus on immutable data reduces bugs in large programs, especially ones involving concurrency.
Functional programming has no place in the object-oriented world, does it?
While object-oriented programming and functional programming are often seen as opposite paradigms, the truth is a bit more complex. Even Java is getting more of a functional style with Java 8’s Lambdas. Scala explicitly blends object-oriented and functional styles. While Clojure is explicitly not object-oriented, it does borrow many good ideas from the object-oriented world, such as polymorphism and programming to interfaces.
Which one should I use? Scala or Clojure? What are the differences and which would be easier to start with?
Scala tends to provide an easier on-ramp for object-oriented programmers, as they can start working with it in a mainly object-oriented style and transition to a more functional style as they gain more experience. Scala also has a sophisticated static type system, and blends object-oriented and functional programming together. Clojure, on the other hand, is a modern, practical Lisp and comes with the powerful macro system inherent to Lisps.
Both are excellent, general-purpose languages, but I have to confess that I prefer Clojure. I find that I can write clear, concise code it in much more easily than I can in any other language. However, knowing both will give you a very broad understanding of modern languages with a functional flavor.
5 tips when you dive into the functional programming world
Tip 1: Look for opportunities to replace object-oriented patterns with simpler functional language features.
Tip 2: Don’t be afraid to create functions that return functions.
Tip 3: Consider composing behaviors using higher order functions rather than building hierarchies.
Tip 4: Reach for higher order functions over collections before recursion.
Tip 5: You often don’t need mutability, even when you think you do! Try to find a higher order function that helps you transform an immutable data structure into a new, immutable data structure rather than modifying it in place.
Contents and Extracts
- How This Book Is Organized
- Pattern Template
- Why Scala and Clojure
- How To Read This Book
- What Is Functional Programming
- Pattern Glossary
- Introducing Tinyweb
- Tinyweb In Java
- Tinyweb In Scala
- Tinyweb In Clojure
- Introduction
- Replacing Functional Interface
- Replacing State Carrying Functional Interface
- Replacing Command excerpt
- Replacing Builder For Immutable Object
- Replacing Iterator
- Replacing Template Method
- Replacing Strategy
- Replacing Null Object
- Replacing Decorator
- Replacing Visitor
- Replacing Dependency Injection
- Introduction
- Tail Recursion excerpt
- Mutual Recursion
- Filter-Map-Reduce
- Chain of Operations
- Function Builder
- Memoization
- Lazy Sequence
- Focused Mutability
- Customized Control Flow
- Domain-Specific Language