Nach den Übungen in der Typclassopedia habe ich versucht, eine Instanz von Functor für Entweder zu implementieren. Mein erster Versuch war die folgende:Typenkonflikt beim Schreiben einer Funktorinstanz für Entweder
instance Functor (Either a) where
fmap f (Right a) = Right (f a)
fmap _ left = left
Dies wirft die folgenden Compiler-Fehler:
functor.hs:7:17:
Couldn't match type ‘a1’ with ‘b’
‘a1’ is a rigid type variable bound by
the type signature for
fmap :: (a1 -> b) -> Either a a1 -> Either a b
at functor.hs:6:3
‘b’ is a rigid type variable bound by
the type signature for
fmap :: (a1 -> b) -> Either a a1 -> Either a b
at functor.hs:6:3
Expected type: Either a b
Actual type: Either a a1
Relevant bindings include
left :: Either a a1 (bound at functor.hs:7:10)
fmap :: (a1 -> b) -> Either a a1 -> Either a b
(bound at functor.hs:6:3)
In the expression: left
In an equation for ‘fmap’: fmap _ left = left
Der einfachste Weg, dies zu lösen, ist die zweite Definition von fmap
wie folgt zu ersetzen:
Kann mir jemand erklären, warum der Fehler durch explizite Mustererkennung in der zweiten Definition von fmap
gelöst wird?