[Haskell-beginners] OOP exercise with closures

Francesco Ariis fa-ml at ariis.it
Tue Dec 29 22:06:54 UTC 2020


Il 29 dicembre 2020 alle 15:43 Lawrence Bottorff ha scritto:
> Okay, I'm in Lesson 10 of *Get Programming with Haskell * and we're
> creating an OOP-like world with closures. The first step is a cup object
> with one attribute, its ounce size. Here's a "constructor"
> 
> cup :: t1 -> (t1 -> t2) -> t2
> cup flOz = \message -> message flOz
> 
> so this returns upon use
> 
> > myCup = cup 6
> 
> myCup which has "internally" a lambda function
> 
> (\message -> message) 6
> 
> waiting, correct?

Not exactly. `myCup` is a function with takes another function as input

    λ> :t myCup
    myCup :: (Integer -> t2) -> t2

and the body looks like this

    \f -> f 6

`\f -> f 6`  is different from  `(\f -> f) 6`!


> Now a "method"
> 
> getOz aCup = aCup (\foz -> foz)
> 
> creates a closure on the lambda function (\foz -> foz) . So upon calling
> 
> > getOz myCup
> 6
> 
> I'm guessing myCup (\foz -> foz) was evaluated, but I don't understand how
> the 6 that went in as the bound variable in the constructor came out again
> with getOz.

To recap, `myCup` expands to:

    myCup
    cup 6
    \message -> message 6

Now, applying `getOz` to it…

    getOz myCup
    myCup (\foz -> foz)
    (\message -> message 6) (\foz -> foz)
    (\foz -> foz) 6
    6



More information about the Beginners mailing list