haskell - 为什么 Data.Tree.Tree 没有幺半群实例?

标签 haskell

我意识到答案可能是存在多个有效的此类实例(例如整数;总和、乘积……的情况)。也许有人有比这更令人满意的答案?

正如 Joachim Breitner 在此答案中出色地解释的那样 How do you implement monoid interface for this tree in haskell?任何应用程序都有一个幺半群实例:

mempty :: Applicative f => Monoid a => f a
mempty = pure mempty

mappend :: Applicative f => Monoid a => f a -> f a -> f a
mappend f g = mappend <$> f <*> g

所以我想知道为什么Data.Tree.Tree来自 containers没有这样的实例吗?相同的参数可以用于没有伴随的 monoid 实例的任何其他 monad。他们应该有这样的例子对我来说似乎很自然。也许事实并非如此。我希望有人能启发我。

我想另一个原因可能是我为树提出的实例并不“有用”。在我看来,这与多个有效实例的论点一样令人不满意。

最佳答案

我不知道为什么它不可用。但是,您建议的实例可通过 Ap 一劳永逸地获得。 newtype,它提供了一个 instance (Applicative f, Monoid m) => Monoid (Ap f m) .所以如果你需要你写的实例,你可以用这个得到它,即使它不存在于裸 Tree 上。类型。

关于haskell - 为什么 Data.Tree.Tree 没有幺半群实例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58082889/

相关文章:

haskell - 在 Haskell 中读取字符串

Haskell 中的字符串格式化

haskell - Yesod,如何从 Javascript/Julius 中的 JSON 数据生成类型安全链接

haskell - 在本地运行 Hoogle

haskell - 转置嵌套数据结构

haskell - Haskell `let` 表达式中的名称捕获

haskell - 如何从函数返回 Data.Map

haskell - 部分记录的安全替代方案?

haskell - 用于生成 Haskell 函数依赖(控制流)图的工具?

haskell - 数据集 : does it always know best?