Functional Programming in Java 8 (Part 0): Motivation
As we begin a series on functional programming, see why you should consider making the move and how you can incorporate it using some familiar Java.
Join the DZone community and get the full member experience.
Join For FreeAs I’ve seen in my previous post, the interest in functional programming is high. This is the reason I want to write an introduction about it.
I work a lot in Haskell and Java in my free time. The idea to combine both of these languages in Java was a dream come true. After this introduction, I hope you will feel the same.
What Is Functional Programming, Really?
You might have heard about functional programming (FP) and how great it is to reduce your LOC and enhance the readability of your code. But what does it really mean to program functional, and what are the main differences to OOP?
1. All Variables Are Final
This is a perfectly valid function to create such a great String in Java.
But if you are fP, this won’t work. You change the state of greeting, which is not allowed in fP. So, if you try to make the greeting final, you will get an error. Every time you use +=
with that String, you change its state.
What you basically do in fP is the concatenation of all names in one line into one String.
If you think that this looks nasty, you’re right! But there is a fP function to make this nicer.
I will give you the right fP function here. Don’t worry if you don’t understand it now; we will talk about all of this in part 3.
The good thing about final variables is that their value is always the same. This makes debugging and testing so much easier!
2. Don’t Use Global Variables (And Forget About Side Effects)
I’ve chosen the example of a global time object. You write a static function, which returns the current time as a String. An OO function could look like this:
If you use currTime
twice, the result will be different because the time will be different. Although we had the same input (which is none), currTime
had two different results!
This can’t happen in fP. Every method only depends on its parameters and on nothing else! So, if we want to do something like this, the Time object has to be a parameter of currTime
:
This might seem odd in the OO world, but it has some benefits.
On one hand, it is much easier to read the code. If you know that a method only relies on its parameter, you don’t have to look for global variables that do the magic in your method. On the other hand, testing is much easier, too! When you want to test the fP currTime
method, you can mock the Time object. In the OO version, it’s really difficult to mock the static Time object.
3. Use Functions as Parameters
In fP, functions can be arguments of another function! How cool is that? Just think of a function which adds 1 to every number of a List<Integer>
. How would you do that, OO? Here’s a snippet:
Now, you have to handle two lists. This can be very confusing and leads to errors. There is also the chance to change the state of numbers. This could lead to problems in later parts of the program.
In fP, you can map a function with every element of a List. In this example, this means that you want to “map” number+1 to every item in the list and store this in a new List.
Don’t worry if you don’t understand all of it now; we will learn about this in part 3. The fP method would look like this:
This reduces the number of variables and, therefore, the places where you can make errors. Here, you create a new list and leave numbers like it is.
Conclusion
I hope you can see the benefits of fP. Later on, you will learn to truly appreciate them. Final variables are a big help in terms of multi-threading. The lack of global variables improves the testability and functions as parameters improve the code quality.
And don’t worry. In the beginning, you can mix OOP and fP in your code.
In the next part, we will talk about functions as parameters. Therefore, I will introduce the anonymous function(lambdas) and method references.
I hope you liked this short introduction to the big topic of functional programming. Please write me when something’s not clear. Or is there any reason for you to hate functional programming at all? I would love to discuss these topics with you.
Published at DZone with permission of Niklas Wuensche, DZone MVB. See the original article here.
Opinions expressed by DZone contributors are their own.
Comments