(a -> a -> Bool) -> [a-6ren">
gpt4 book ai didi

haskell 错误 "No instance for (Eq a0) arising from a use of..."

转载 作者:行者123 更新时间:2023-12-03 07:05:26 31 4
gpt4 key购买 nike

有人知道为什么下面的代码在“matchListWith eq [] []”中失败吗?

--失败.hs

matchListWith :: (Eq a) => (a -> a -> Bool) -> [a] -> [a] -> Bool
matchListWith f (x:xs) (y:ys) = (f x y) && (matchListWith f xs ys)
matchListWith _ [] [] = True
matchListWith _ _ _ = False

eq :: (Eq a) => a -> a -> Bool
eq a b = (a == b)

main = do
print (matchListWith eq [1, 3] [1, 3])
print (matchListWith eq [1, 3] [1])
print (matchListWith eq [1] [1, 3])
print (matchListWith eq [3, 1] [1, 3])
print (matchListWith eq [1] [])
print (matchListWith eq [] [])

--eof

错误是:

failure.hs:16:11:
No instance for (Eq a0) arising from a use of `matchListWith'
The type variable `a0' is ambiguous
Possible fix: add a type signature that fixes these type variable(s)
Note: there are several potential instances:
instance Eq a => Eq (GHC.Real.Ratio a) -- Defined in `GHC.Real'
instance Eq () -- Defined in `GHC.Classes'
instance (Eq a, Eq b) => Eq (a, b) -- Defined in `GHC.Classes'
...plus 22 others
In the first argument of `print', namely `(matchListWith eq [] [])'
In a stmt of a 'do' block: print (matchListWith eq [] [])
In the expression:
do { print (matchListWith eq [1, 3] [1, 3]);
print (matchListWith eq [1, 3] [1]);
print (matchListWith eq [1] [1, 3]);
print (matchListWith eq [3, 1] [1, 3]);
.... }

奇怪的是,如果我在 GHCi 中加载两个函数 matchListWith eq [] [],工作得很好。

*Main> matchListWith eq [] []
True
*Main>

我使用的是 GHC 版本 7.6.3。

最佳答案

原因是因为当你打电话

matchListWith eq [] []

编译器不知道它是什么类型的列表。它只知道它是一个 [a] 类型的值,但这并没有对其施加 Eq a => 约束。将其更改为

matchListWith eq [] ([] :: [Int])

它应该编译

<小时/>

有时您必须为 GHC 提供一些帮助才能了解它正在处理哪些类型。如果你尝试过也会是一样的

myFunc :: m Int
myFunc = do
let x = 1
y = 2
return $ x + y

这不会编译,因为编译器没有被告知 mMonad,您必须添加额外的上下文

myFunc :: Monad m => m Int

让它发挥作用。

它在 GHCi 中起作用的原因是因为有更急切的类型推断。 GHCi 通常会选择比 GHC 更具体的类型,以使交互部分更易于使用。

关于 haskell 错误 "No instance for (Eq a0) arising from a use of...",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20340292/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com