最近翻以前的代码的时候发现了一个问题 ,先看一下下面代码
def test():
for i in xrange(2):
print 'before', i
for i in xrange(2, 4):print 'middle', i
print 'after', i
看到代码之后,发现内层for循环变量和外层的循环的名字一致,这样的代码在执行之后外层循环能执行几次呢?
执行结果
before 0
middle 2
middle 3
after 3
before 1
middle 2
middle 3
after 3
可以看到,外层循环也按照正常次数执行,内层的变量 i 没有影响到外城的执行,虽然在内层执行之后 i 值发生了改变。
仔细想了一下,大致明白了其中的原委。
Python不像c++,在c++,中声明一个变量需要带上类型,声明之后这个变量已经指向了地址空间,二Python不需要这样,Python中的变量只是个符号,赋值只是把变量和内存地址存储的对象关联起来。
上面代码中的执行流程可以看成这样
1 第一次执行 把 0 的地址和 i 关联起来
2 执行内部循环 不断变换 i 关联的地址
3 执行第二次外部循环 把 1 和 i 关联起来
那么同样的代码 在 c中会是什么输出呢
代码如下
#include <stdio.h>
int main()
{
int i,j,k;
for(i=0;i<2;i++) {
printf("before %d\n", i);
for (i=2; i<4; i++) {
printf("middle %d\n", i);
}
printf("after %d\n", i);
}
return 0;
}
输出如下
before 0
middle 2
middle 3
after 4
通过比较,发现Python还是真的与众不同。
以上只是个人的见解,需要了解更多的东西的话,推荐大家看一下 《Python源码剖析》 ,看完就能更好理解了。