Maison >développement back-end >Tutoriel Python >Pourquoi Python Lambda se lie-t-il aux références locales au moment de l'invocation, et non au moment de la création ?

Pourquoi Python Lambda se lie-t-il aux références locales au moment de l'invocation, et non au moment de la création ?

DDD
DDDoriginal
2024-10-29 21:41:29465parcourir

Why does Python Lambda bind to local references at invocation time, not creation time?

Liaison de Python Lambda aux références locales

Le code suivant imprime « 1 » deux fois au lieu de « 0 » et « 1 » :

<code class="python">def pv(v):
  print v

x = []
for v in range(2):
  x.append(lambda: pv(v))

for xx in x:
  xx()</code>

Pour comprendre ce comportement, il est crucial de comprendre comment les lambdas Python interagissent avec les variables locales. Contrairement aux attentes, les lambdas ne se lient pas intrinsèquement aux références des variables locales au moment de leur création. Au lieu de cela, ils se lient aux valeurs des variables récupérées au moment de leur invocation.

Pour remédier à ce problème et lier correctement les variables locales aux fonctions lambda, il est nécessaire d'utiliser un argument par défaut pour le lambda. En définissant la valeur par défaut de la variable dans la définition lambda (par exemple, lambda v=v : pv(v)), le lambda fera référence à la valeur de la variable lors de sa création.

Ce comportement est pas exclusif aux lambdas. Prenons l'exemple suivant :

<code class="python">x = "before foo defined"

def foo():
    print x

x = "after foo was defined"

foo()</code>

La sortie de ce code sera "après la définition de foo", car Python recherche la valeur de x au moment où la fonction est appelée, plutôt qu'au moment de sa création. .

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn