haskell - 为什么 TypeSynonymInstances 不允许在实例头中使用部分应用的类型同义词?

标签 haskell

我知道TypeSynomymInstances only allows fully applied type synonyms to be used in instance heads ,但如果我也可以使用部分应用的类型同义词似乎会很方便。

例如:

class Example e where
  thingy :: a -> b -> e a b

-- legit, but awkward
newtype FuncWrapper e a b = FuncWrapper { ap :: a -> e a b }
instance (Example e) => Example (FuncWrapper e) where
  thingy _ = FuncWrapper . flip thingy
funcWrapperUse :: (Example e) => e Int String
funcWrapperUse = thingy 1 "two" `ap` 3 `ap` 4 `ap` 5

-- not legal, but a little easier to use
type FuncSynonym e a b = a -> e a b
instance (Example e) => Example (FuncSynonym e) where
  thingy _ = flip thingy
funcSynonymUse :: (Example e) => e Int String
funcSynonymUse = thingy 1 "two" 3 4 5

最佳答案

Haskell 中根本不允许使用部分应用的类型同义词。部分应用的同义词实际上是一个函数,其输入是未应用的类型,其输出是一个类型。例如,这里是 bool 逻辑的编码:

type True x y = x
type False x y = y
type Not b x y = b y x
type And b1 b2 x y = b1 (b2 x y) y
type Or b1 b2 x y = b1 x (b2 x y)

要确定两个部分应用的类型同义词是否相等,类型检查器必须确定函数是否相等。这是一个很难解决的问题,一般来说它是不可判定的。

关于haskell - 为什么 TypeSynonymInstances 不允许在实例头中使用部分应用的类型同义词?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4922560/

相关文章:

haskell - 在 NixOS 中使用堆栈 1.8.0 (当前 `stack upgrade --git` )?

haskell - cabal 没有找到 Source.hs

haskell - 我无法阻止 Haskell 列出数字

haskell - Haskell 中图的传递闭包

haskell - 在 Haskell 中使用表情符号

windows - 编译 qtHaskell 时出错

list - 使用 Haskell 的 map 函数计算列表的总和

haskell - 使用 MonadPrompt 实现回放

haskell - 默认方法中对幻像类型的类约束的编译错误

haskell - 部分应用程序和子表达式仅取决于函数参数的一个子集