Why isn't (->) implemented with Control.Monad.

2019-06-21 18:44发布

I was reading LYAH. It says I need to explicitly load Control.Monad.Instances to get the following syntax to work:

( ( fmap (+5) ) (+5) ) 4

Why is that? Why if functors are this underlying and unifying technology do I have to explicitly load Control.Monad.Instances to get that functionality. How is (->) implemented without it (or is just hidden and only -> exported)? Why isn't the use of fmap over function types implemented by default?

2条回答
做自己的国王
2楼-- · 2019-06-21 19:17

Functor is not a language feature, it is just a useful typeclass that a random module happens to define. To use that module's definition of Functor, you have to load it, end of story.

查看更多
太酷不给撩
3楼-- · 2019-06-21 19:28

There are 3 different concepts involved here. The function type, the Functor type class, and the Functor "instance". The function type, (->), is built into the language and its existence and implementation are completely unrelated to Functor and fmap. The type class is the specification of the signature of its associated methods. The "instance" is an implementation of that signature.

So to make your question clearer, I would re-phrase it as "why isn't the Functor instance for (->) provided in the Prelude?" (the Prelude being the module that's in scope by default). As it is currently phrased, it doesn't make a lot of sense.

The answer to the modified question is simple: the Haskell Report (the official language specification, which is where the Prelude's interface is specified) doesn't include it. Arguably it should, but the Haskell language and libraries have evolved a lot since then, and Haskell standards tend to change slowly. In any case, right or wrong, that's why.

查看更多
登录 后发表回答