当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Elixir Enum.sort用法及代码示例


Elixir语言中 Enum.sort 相关用法介绍如下。

用法一

sort(enumerable)
@spec sort(t()) :: list()

根据 Erlang 的术语排序对 enumerable 进行排序。

该函数使用归并排序算法。不要使用此函数对结构进行排序,有关详细信息,请参阅 sort/2

例子

iex> Enum.sort([3, 2, 1])
[1, 2, 3]

用法二

sort(enumerable, fun)
@spec sort(
  t(),
  (element(), element() -> boolean())
  | :asc
  | :desc
  | module()
  | {:asc | :desc, module()}
) :: list()

按给定函数对enumerable 进行排序。

该函数使用归并排序算法。给定的函数应该比较两个参数,如果第一个参数在第二个参数之前或在同一个位置,则返回true

例子

iex> Enum.sort([1, 2, 3], &(&1 >= &2))
[3, 2, 1]

只要给定函数为被认为相等的值返回true,排序算法就会稳定:

iex> Enum.sort(["some", "kind", "of", "monster"], &(byte_size(&1) <= byte_size(&2)))
["of", "some", "kind", "monster"]

如果函数不为相等的值返回true,则排序不稳定,相等项的顺序可能会打乱。例如:

iex> Enum.sort(["some", "kind", "of", "monster"], &(byte_size(&1) < byte_size(&2)))
["of", "kind", "some", "monster"]

上升和下降

sort/2 允许开发者传递:asc:desc作为排序函数,分别为 <=/2 >=/2 提供方便。

iex> Enum.sort([2, 3, 1], :asc)
[1, 2, 3]
iex> Enum.sort([2, 3, 1], :desc)
[3, 2, 1]

排序结构

排序结构时不要使用 </2 <=/2 >/2 >=/2 和朋友。这是因为上面的内置运算符执行的是结构比较,而不是语义比较。假设我们对以下日期列表进行排序:

iex> dates = [~D[2019-01-01], ~D[2020-03-02], ~D[2019-06-06]]
iex> Enum.sort(dates)
[~D[2019-01-01], ~D[2020-03-02], ~D[2019-06-06]]

请注意,返回的结果是不正确的,因为 sort/1 默认使用 <=/2 ,它将比较它们的结构。在比较结构时,字段按字母顺序进行比较,这意味着上面的日期将按 daymonthyear 进行比较,这与我们想要的相反。

出于这个原因,大多数结构都提供了一个"compare"函数,例如 Date.compare/2 ,它接收两个结构并返回:lt(小于)、:eq(等于)和:gt(大于)。如果你传递一个模块作为排序函数,Elixir 会自动使用该模块的compare/2 函数:

iex> dates = [~D[2019-01-01], ~D[2020-03-02], ~D[2019-06-06]]
iex> Enum.sort(dates, Date)
[~D[2019-01-01], ~D[2019-06-06], ~D[2020-03-02]]

要按降序检索所有日期,您可以将模块包装在以:asc:desc 作为第一个元素的元组中:

iex> dates = [~D[2019-01-01], ~D[2020-03-02], ~D[2019-06-06]]
iex> Enum.sort(dates, {:asc, Date})
[~D[2019-01-01], ~D[2019-06-06], ~D[2020-03-02]]
iex> dates = [~D[2019-01-01], ~D[2020-03-02], ~D[2019-06-06]]
iex> Enum.sort(dates, {:desc, Date})
[~D[2020-03-02], ~D[2019-06-06], ~D[2019-01-01]]

相关用法


注:本文由纯净天空筛选整理自elixir-lang.org大神的英文原创作品 Enum.sort(enumerable)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。