从Python文档关于Naming and binding的说明可知,变量名是绑定到具体对象的,从这点来看,可以把它理解为C++中的引用。考虑下面两行语句:
第2行执行后,同理,值为'test_ext'的string对象被创建出来,变量名a重新绑定到这个新对象上。此时,'test'对象已经无法通过a访问到了。
再次强调:这两行语句的行为与C/C++中的行为完全不同!在C语言中,int a = 1执行后,会创建出名为a且大小为sizeof(int)的内存单元(当然,由于编译器会对内存做alinging优化,所以实际申请的内存大小可能不只sizeof(int)),该内存单元存放int值1,而 a = 2执行后,a代表的内存单元地址不变,其值更新为2。
a = 'test'
a = 'test_ext'
第1行执行后,Python解释器会在内存中创建string类型的对象'test',这个对象一旦创建就不能再修改其值。赋值符号只是将变量名a绑定到这个对象上而已。
第2行执行后,同理,值为'test_ext'的string对象被创建出来,变量名a重新绑定到这个新对象上。此时,'test'对象已经无法通过a访问到了。
再次强调:这两行语句的行为与C/C++中的行为完全不同!在C语言中,int a = 1执行后,会创建出名为a且大小为sizeof(int)的内存单元(当然,由于编译器会对内存做alinging优化,所以实际申请的内存大小可能不只sizeof(int)),该内存单元存放int值1,而 a = 2执行后,a代表的内存单元地址不变,其值更新为2。
关于上述Python Naming Rule的行为,我之前写过一篇笔记简单分析过,这里不再赘述。