elixir - 9 . 使用Enum.map , pipe operator, stream

栏目: 编程语言 · 发布时间: 7年前

内容简介:参考:iex(2)> Enum.map([1,2,3], fn x -> x * 2 end )[2, 4, 6]

参考: https://elixir-lang.org/getting-started/enumerables-and-streams.html

iex(2)> Enum.map([1,2,3], fn x -> x * 2 end )

[2, 4, 6]

iex(3)> Enum.map(%{ 1 => 3, 5 => 27}, fn {k,v} -> k * v end )

[3, 135]

iex(4)> [1,2,3]

> Enum.map( (1..9), fn x -> 2*x + 1 end )

[3, 5, 7, 9, 11, 13, 15, 17, 19]

odd? = &( rem(&1, 2) != 0)  # 这里定义了取偶数的方法。 可以看出 &( ... ) 中的代码,默认是 返回 boolean

iex >  Enum.filter( 5..9, odd?)     # 这里可以看出, Enum.filter 接受两个参数。 第二个是一个fn

[5, 7, 9]

)> total_sum = 1..300 |> Enum.map(fn(x) -> x + 3 end) |> Enum.filter(&( rem(&1, 2) == 0))

[4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42,

44, 46, 48, 50, 52, 54, 56, 58, 60, 62, 64, 66, 68, 70, 72, 74, 76, 78, 80, 82,

84, 86, 88, 90, 92, 94, 96, 98, 100, 102, ...]

Stream.  每次pipe 返回的不是一个List(不是一个方法结果),而是使用Stream对传入的数据进行的处理。

iex(30)> 1..100_000

1..100000

iex(31)> 1..100_000 |> Stream.map(&(&1 * 3))

#Stream<[enum: 1..100000, funs: [#Function<49.117072283/1 in Stream.map/2>]]>

iex(32)> 1..100_000 |> Stream.map(&(&1 * 3)) |> Stream.filter(&(rem(&1, 2) == 0))

#Stream<[

enum: 1..100000,

funs: [#Function<49.117072283/1 in Stream.map/2>,

#Function<41.117072283/1 in Stream.filter/2>]

]>

iex(33)> 1..100_000 |> Stream.map(&(&1 * 3)) |> Stream.filter(&(rem(&1, 2) == 0)) |> Enum.sum

7500150000

Stream特别适合 大数据的计算,例如 无限长 , 无限大的结果。 (到 pipe operator的最后一刻才知道多大)


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Linux多线程服务端编程

Linux多线程服务端编程

陈硕 / 电子工业出版社 / 2013-1-15 / 89.00元

本书主要讲述采用现代C++ 在x86-64 Linux 上编写多线程TCP 网络服务程序的主流常规技术,重点讲解一种适应性较强的多线程服务器的编程模型,即one loop per thread。这是在Linux 下以native 语言编写用户态高性能网络程序最成熟的模式,掌握之后可顺利地开发各类常见的服务端网络应用程序。本书以muduo 网络库为例,讲解这种编程模型的使用方法及注意事项。 本......一起来看看 《Linux多线程服务端编程》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具