The idea of functionN in Scala / Functionaljava
Posted
by
Luke Murphy
on Programmers
See other posts from Programmers
or by Luke Murphy
Published on 2012-11-24T14:43:12Z
Indexed on
2012/11/24
17:17 UTC
Read the original article
Hit count: 255
It turns out, that every Function you’ll ever define in Scala, will become an instance of an Implementation which will feature a certain Function Trait.
There is a whole bunch of that Function Traits, ranging from Function1 up to Function22.
Since Functions are Objects in Scala and Scala is a statically typed language, it has to provide an appropriate type for every Function which comes with a different number of arguments. If you define a Function with two arguments, the compiler picks Function2 as the underlying type.
Also, from Michael Froh's blog
You need to make FunctionN classes for each number of parameters that you want? Yes, but you define the classes once and then you use them forever, or ideally they're already defined in a library (e.g. Functional Java defines classes F, F2, ..., F8, and the Scala standard library defines classes Function1, ..., Function22)
So we have a list of function traits (Scala), and a list of interfaces (Functional-java) to enable us to have first class funtions.
I am trying to understand exactly why this is the case. I know, in Java for example, when I write a method say,
public int add(int a, int b){
return a + b;
}
That I cannot go ahead and write
add(3,4,5);
( error would be something like : method add cannot be applied to give types )
We simply have to define an interface/trait for functions with different parameters, because of static typing?
© Programmers or respective owner