python中内置函数map
Return an iterator that applies function to every item of iterable, yielding the results.
1 | a = map(fun, iterable) |
a是一个迭代器,是惰性的;换句话说就是,执行上面一句代码,fun
函数并没有执行,只有调用next(a)
时,才会执行fun
函数(体现了迭代器的特点:按需获取)。
验证的例子如下:
1 | >>> def fun(value): |
生成器原理和这差不多。
concurrent.futures中map
函数
Equivalent to map(func, *iterables) except func is executed asynchronously and several calls to func may be made concurrently.
官方文档说和内置map
函数差不多,只不过函数func
可能被同时调用。但实际情况是有一点差别的,下面进行说明。
1 | a = executor.map(func, *iterables, timeout=None, chunksize=1) |
a是一个生成器,是惰性的,但是执行上面一行代码后,func
函数执行了(注意和内置map
函数区别);这个返回的生成器只是针对函数func
返回的结果而言的。
验证的例子如下:
1 | from concurrent.futures import ThreadPoolExecutor |
结果:
1 | >>> python3 test.py |
为进一步探究其原因,看一下concurrent.futures中map
函数的源码。
模块的位置如下:
1 | >>> import concurrent.futures |
对应map
源码的位置/usr/lib/python3.5/concurrent/futures/_base.py
1 | def map(self, fn, *iterables, timeout=None, chunksize=1): |
根据源码可知,第5行列表推到,函数fun
已经被调用,最后返回是fun
函数调用结果的生成器。和上面的讨论一致。
结束。