给定一个具有静态类型长度的列表(以此为例):
data Zero
data Succ nat
data List el len where
Nil :: List el Zero
Cons :: el -> List el len -> List el (Succ len)
是否可以编写一个长度函数来使用静态类型而不是通常的递归来计算长度?
到目前为止,我的努力使我得出的结论是,这是不可能的,因为它需要“取消”类型信息才能再次出现:
class HasLength a where
length :: a -> Natural
instance HasLength (List el Zero) where
length _ = 0
instance HasLength (List el (Succ len)) where
length _ = 1 + *how to recur on type of len*
但是,我才刚刚开始了解类型可能具有的所有魔力,所以我知道我无法构想解决方案并不意味着没有解决方案。
更新
由于长度返回自然,我错误地写了length _ = 1 + ...
. 正确的实例(使用下面给出的答案)是
instance HasLength (List el len) => HasLength (List el (Succ len)) where
length _ = succ $ length (undefined :: List el len)