Elixir语言中 Enum.chunk_while
相关用法介绍如下。
用法:
chunk_while(enumerable, acc, chunk_fun, after_fun)
(从 1.5.0 开始)
@spec chunk_while(
t(),
acc(),
(element(), acc() -> {:cont, chunk, acc()} | {:cont, acc()} | {:halt, acc()}),
(acc() -> {:cont, chunk, acc()} | {:cont, acc()})
) :: Enumerable.t()
when chunk: any()
当发出每个块时,使用细粒度控制对 enumerable
进行块。
chunk_fun
接收当前元素和累加器,必须返回:
{:cont, chunk, acc}
发出一个块并继续使用累加器{:cont, acc}
不发出任何块并继续使用累加器{:halt, acc}
停止在enumerable
上进行分块。
当迭代完成(或 halt
ed)时,使用最终累加器调用 after_fun
以处理作为累加器的一部分返回但未被 chunk_fun
作为块发出的任何尾随元素。它必须返回:
{:cont, chunk, acc}
发出一个块。该块将被附加到已发出的块列表中。{:cont, acc}
不发出块
after_fun
中的 acc
是必需的,以便从 chunk_fun
镜像元组格式,但由于遍历完成,它将被丢弃。
返回发出的块的列表。
例子
iex> chunk_fun = fn element, acc ->
...> if rem(element, 2) == 0 do
...> {:cont, Enum.reverse([element | acc]), []}
...> else
...> {:cont, [element | acc]}
...> end
...> end
iex> after_fun = fn
...> [] -> {:cont, []}
...> acc -> {:cont, Enum.reverse(acc), []}
...> end
iex> Enum.chunk_while(1..10, [], chunk_fun, after_fun)
[[1, 2], [3, 4], [5, 6], [7, 8], [9, 10]]
iex> Enum.chunk_while([1, 2, 3, 5, 7], [], chunk_fun, after_fun)
[[1, 2], [3, 5, 7]]
相关用法
- Elixir Enum.chunk_every用法及代码示例
- Elixir Enum.chunk_by用法及代码示例
- Elixir Enum.count用法及代码示例
- Elixir Enum.concat用法及代码示例
- Elixir Enum.count_until用法及代码示例
- Elixir Enum.unzip用法及代码示例
- Elixir Enum.min_max用法及代码示例
- Elixir Enum.reduce_while用法及代码示例
- Elixir Enum.at用法及代码示例
- Elixir Enum.split_with用法及代码示例
- Elixir Enum.dedup用法及代码示例
- Elixir Enum.sum用法及代码示例
- Elixir Enum.zip用法及代码示例
- Elixir Enum.find_value用法及代码示例
- Elixir Enum.product用法及代码示例
- Elixir Enum.map_join用法及代码示例
- Elixir Enum.zip_with用法及代码示例
- Elixir Enum.intersperse用法及代码示例
- Elixir Enum.flat_map用法及代码示例
- Elixir Enum.fetch用法及代码示例
- Elixir Enum.frequencies用法及代码示例
- Elixir Enum.drop用法及代码示例
- Elixir Enum.slice用法及代码示例
- Elixir Enum.max_by用法及代码示例
- Elixir Enum.zip_reduce用法及代码示例
注:本文由纯净天空筛选整理自elixir-lang.org大神的英文原创作品 Enum.chunk_while(enumerable, acc, chunk_fun, after_fun)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。