Lambdas dentro de la lista de comprensiones.
Quería tener una lista de lambdas que actúan como una especie de caché para algunos cálculos pesados y noté esto:
<code>>>> [j() for j in [lambda:i for i in range(10)]] [9, 9, 9, 9, 9, 9, 9, 9, 9, 9] </code>
A pesar de que
<code>>>> list([lambda:i for i in range(10)]) [<function <lambda> at 0xb6f9d1ec>, <function <lambda> at 0xb6f9d22c>, <function <lambda> at 0xb6f9d26c>, <function <lambda> at 0xb6f9d2ac>, <function <lambda> at 0xb6f9d2ec>, <function <lambda> at 0xb6f9d32c>, <function <lambda> at 0xb6f9d36c>, <function <lambda> at 0xb6f9d3ac>, <function <lambda> at 0xb6f9d3ec>, <function <lambda> at 0xb6f9d42c>] </code>
Lo que significa que las lambdas son funciones únicas pero de alguna manera todas comparten el mismo valor de índice.
¿Es este un error o una característica? ¿Cómo evito este problema? No se limita a listas de comprensión ...
<code>>>> funcs = [] ... for i in range(10): ... funcs.append(lambda:i) ... [j() for j in funcs] [9, 9, 9, 9, 9, 9, 9, 9, 9, 9] </code>