我想在代码中为某些本地函数添加类型签名。但是,它们的类型涉及匿名的,存在性绑定的类型变量。由于它们是匿名的,我不知道如何编写类型签名。我怎样才能引用这种类型变量?
在以下示例中,go
的类型为[b] -> Int -> Int
,其中b
是由模式匹配T (x_shared:xs) g
绑定的类型。我可以为它写什么类型的签名?
data T = forall a. T [a] (a -> a -> Int)
f :: T -> Int
f (T (x_shared:xs) g) = go xs 0
where
-- go :: what type?
go (x:xs) n = go xs $! n + g x_shared x
go [] n = n
答案 0 :(得分:15)
使用ScopedTypeVariables
扩展名,您可以向g
添加类型注释,并将类型变量a
引入范围。
f (T (x_shared:xs) (g :: a -> a -> Int)) = go xs 0
然后,您可以使用go
为a
写一个类型签名。
go :: [a] -> Int -> Int