map和reduce都是python里面的高阶函数
高阶函数简单来说就是:一个函数可以将函数作为自身的参数,则称之为高阶函数
哦哟哟,是不是比一般性的函数厉害那么一点点,那么map和reduce是不是也会厉害那么一些呢?------是的(反正我觉得map是的,reduce对不起)
来,先介绍一下map函数的定义:
map()
函数接收两个参数,一个是函数,一个是Iterable
,map
将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator
返回
这里有人会问Iterator
是什么,百度去吧少年,大概说一下反正List和str是的,必须可以由for循环的变量,当然这只是初步的,但显然int就不是了嘛
给个map函数的示范吧,一看就懂
从这里我们可以看出一个特性,map函数因为有一个参数是Iterable,
并且这也是对Iterable
进行操作,那么结果必然是惰性的,这是Iterable
的性质,那么产生的结果可以用next()依次输出,也可以才改变形态后一下子全输出,这取决于你想干嘛咯
好咯,接下来就是reduce了
reduce也接收两个参数一个是函数,一个是变量(注意,不用是Iterable,
所以没惰性),但作用不同:reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
emmmm……这么大概可以理解吧,给个辅助例子吧