微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Haskell 数据结构未加载

如何解决Haskell 数据结构未加载

我正在尝试建立一个数据结构,它是 lambda 演算的扩展,以允许加法和减法。我正在尝试创建一个称为 AE 的结构,它可以将 Lit 作为其本身,也可以计算加法和减法。我收到的错误说明如下:

无效的类型签名:Lit :: ...

应该是表单变量::类型

点燃 :: Int -> AE​​p>

我对这个数据结构的声明有什么问题?

{-# Language GADTs #-}
data AE where
Lit :: Int -> AE
Add :: Int -> Int ->  AE
Sub :: Int -> Int ->  AE

deriving (Show)


eval  ::  AE ->  Maybe Int
eval (Lit n) = Just n
eval (Add n1 n2) = n1 + n2
eval (Sub n1 n2) = do
                      if(n1<n2) then return nothing
                      else return n1 - n2

解决方法

您需要缩进 where 子句下的数据构造函数,因此:

{-# Language GADTs #-}

data AE where
    Lit :: Int -> AE
    Add :: Int -> Int -> AE
    Sub :: Int -> Int -> AE

否则,您将定义一个类型 AE 没有任何数据构造函数。如果缩进,则它是 data AE where 块的一部分,因此您定义了三个数据构造函数。

您的 eval 函数还包含一个 do 块。尽管 MaybeMonad 的一个实例,但您不能像这样使用 do 表示法。尤其是 return nothing 部分在这里是有问题的。对于 Monad 实例 Maybereturn = Just,这意味着 return Nothing 将构造一个 Maybe (Maybe a)。您可以使用警卫来定义警卫应该“开火”的条件。

另一个问题是n1 + n2。这具有类型 Int,而不是 Maybe Int,因此您需要将其包装到 Just 数据构造函数中:

eval :: AE ->  Maybe Int
eval (Lit n) = Just n
eval (Add n1 n2) = Just (n1 + n2)
eval (Sub n1 n2)
    | n1 < n2 = Nothing
    | otherwise = Just (n1 - n2)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。