Я попадал в ничтожный тип файловой системы haskell и пытаюсь понять тонкости классов классов. Я узнал кучу, но я нажимаю на стену на следующих фрагментах кода.
Используя эти определения класса и экземпляра:
class Show a => C a where
f :: Int -> a
instance C Integer where
f x = 1
instance C Char where
f x = if x < 10 then 'c' else 'd'
Почему это проходит проверку типа:
g :: C a => a -> Int -> a
g x y = f y
yes :: C a => a -> Int -> String
yes x y = show (g x y)
но это не так?
g :: C a => a -> Int -> String
g x y = show(f y)
Я нахожу вторую альтернативу более читаемой, и это, по-видимому, лишь незначительная разница (обратите внимание на подписи типа). Однако, пытаясь получить это, результат typechecker приводит к:
*Main> :l typetests.hs
[1 of 1] Compiling Main ( typetests.hs, interpreted )
typetests.hs:11:14:
Ambiguous type variable `a0' in the constraints:
(C a0) arising from a use of `f' at typetests.hs:11:14
(Show a0) arising from a use of `show' at typetests.hs:11:9-12
Probable fix: add a type signature that fixes these type variable(s)
In the first argument of `show', namely `(f y)'
In the expression: show (f y)
In an equation for `g': g x y = show (f y)
Failed, modules loaded: none.
И я не понимаю, почему.
Примечание. Пожалуйста, не спрашивайте: "Что вы пытаетесь сделать?" Я надеюсь, что очевидно, что я просто возился в абстрактном контексте, чтобы исследовать, как работает этот язык. У меня нет цели, кроме изучения чего-то нового.
Спасибо