Fof*_*Fof 2 haskell types unification ghci
我试图推导出类型 (.) (foldr(++)) (map (:))
我首先推导出类型 foldr (++)
foldr :: (a1 -> b1 -> b1) -> b1 -> [a1] -> b1
(++) :: [a2] -> [a2] -> [a2]
a1 ~ [a2]
b1 ~ [a2]
b1 ~ [a2]
Run Code Online (Sandbox Code Playgroud)
所以
foldr (++) :: [a2] -> [[a2]] -> [a2] ~ [a] -> [[a]] -> [a]
Run Code Online (Sandbox Code Playgroud)
然后我推导出类型 map (:)
map :: (a1 -> b1) -> [a1] -> [b1]
(:) :: a2 -> [a2] -> [a2]
a1 ~ a2
b1 ~ [a2] -> [a2]
Run Code Online (Sandbox Code Playgroud)
所以
map (:) :: [a2] -> [[a2] -> [a2]] ~ [a] -> [[a] -> [a]]
Run Code Online (Sandbox Code Playgroud)
最后的类型 (.) (foldr(++)) (map (:))
(.) :: (b1 -> c1) -> (a1 -> b1) -> a1 -> c1
map (:) :: [a2] -> [[a2] -> [a2]]
foldr (++) :: [a3] -> [[a3]] -> [a3]
b1 ~ [a2]
c1 ~ [[a2] -> [a2]]
a1 ~ [a3]
b1 ~ [[a3]] -> [a3]
Run Code Online (Sandbox Code Playgroud)
所以我明白了
(.) (foldr(++)) (map (:)) :: a1 -> c1 ~ [a3] -> [[a2] -> [a2]]
Run Code Online (Sandbox Code Playgroud)
但如果我问GHCi :t (.) (foldr(++)) (map (:))我得到了(.) (foldr(++)) (map (:)) :: [a] -> [[[a] -> [a]]] -> [[a] -> [a]]
哪个与我的结果不同,是否有任何帮助来得出相同的结果?
谢谢,
塞巴斯蒂安.