为什么python函数在定义之前可以在全局范围内使用变量?

时间:2013-10-16 21:37:45

标签: python

def foo(i):
  print len(A)
  return i < len(A)

if __name__ == '__main__':
  A = [12]
  print A 
  foo(10)

foo如何了解A

我写这篇是因为stackoverflow坚持要我写更多的单词。

3 个答案:

答案 0 :(得分:5)

检查生成的字节码:

>>> dis.dis(foo)
  2           0 LOAD_GLOBAL              0 (print) 
              3 LOAD_GLOBAL              1 (len) 
              6 LOAD_GLOBAL              2 (A) 
              9 CALL_FUNCTION            1 (1 positional, 0 keyword pair) 
             12 CALL_FUNCTION            1 (1 positional, 0 keyword pair) 
             15 POP_TOP              

  3          16 LOAD_FAST                0 (i) 
             19 LOAD_GLOBAL              1 (len) 
             22 LOAD_GLOBAL              2 (A) 
             25 CALL_FUNCTION            1 (1 positional, 0 keyword pair) 
             28 COMPARE_OP               0 (<) 
             31 RETURN_VALUE

要加载A变量,它会使用LOAD_GLOBAL操作码。因此,当函数运行时(而不是定义),它将在全局命名空间中搜索此变量

答案 1 :(得分:4)

A是一个全局变量。您可能认为它是if __name__ == '__main__'块的本地,但是if statements do not create a separate namespace in Python。执行foo(未定义)时,变量A存在于全局命名空间中,因此您当前的代码运行时没有任何问题。

如果您想要查看预期的行为,请将该块中的所有内容移动到一个函数中,然后从if __name__ == '__main__'块中调用它:

def foo(i):
  print len(A)      # A is local to main(), so this will raise an exception
  return i < len(A)

def main():
  A = [12]
  print A 
  foo(10)

if __name__ == '__main__':
  main()

答案 2 :(得分:2)

因为A是在全局范围内定义的,并且在调用之前不会在函数中查找。

这是同样的原因

def should_fail():
   print undefined_variable

print "runs OK!"

运行正常。