如何从Haskell中的(G)ADT参数获取构造函数? 有可能做这样的事吗?
data Ex1 = C1 Int | C2 Int -- | .....
| C3
fun :: Ex1 -> Ex1
fun C3 = C3
fun (c i) = c $ i^2
我不适合。
fun (C1 i) = C1 $ i^2
fun (C2 i) = C2 $ i^2
答案 0 :(得分:6)
如果您可以更改Ex1
的类型,那么:
{-# LANGUAGE DeriveFunctor #-}
data Ex1 a = C1 a | C2 a
| C3 deriving (Show, Functor)
fun :: Ex1 Int -> Ex1 Int
fun y = fmap (\x -> x^2) y
ghci
演示:
λ> fun $ C1 3
C1 9
λ> fun $ C2 3
C2 9
λ> fun C3
C3