首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Data.Semigroup ((<>))在这个Haskell排序代码中做什么?

Data.Semigroup ((<>))在这个Haskell排序代码中做什么?
EN

Stack Overflow用户
提问于 2020-04-06 10:39:32
回答 1查看 156关注 0票数 5

该程序可以按Mfg或年份对列表进行排序。什么是(<>)?

代码语言:javascript
复制
import Data.Semigroup ((<>))

compare = comparing year <> comparing mfg
.
.
.
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-06 11:00:51

import Data.Semigroup ((<>))在你的程序中没有做任何有用的事情,自从2015年GHC7.10发布以来,就没有做过任何有用的事情。在此之前,它将<>操作符引入作用域,以便compare = flip (comparing year) <> comparing mfg可以使用它。在GHC 7.10中,运算符被添加到Prelude中,因此即使没有导入,它现在也始终在作用域中。

至于<>在那里做了什么,您将在Vehicle -> Vehicle -> Ordering类型中使用它。它来自Semigroup b => Semigroup (a -> b)实例(两次)和Semigroup Ordering实例。净效果是,在将两个Vehicles应用于它之后,它将使用它们的左侧比较结果(flip (comparing year)),除非它是EQ,在这种情况下,它将使用它们的右侧比较(comparing mfg)。如果你要手写出它到底在做什么,它会是这样的:

代码语言:javascript
复制
compare x y = case flip (comparing year) x y of
  LT -> LT
  EQ -> comparing mfg x y
  GT -> GT
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61052195

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档