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>

Respuestas a la pregunta(5)

Su respuesta a la pregunta