a = [1,3,5] b = a b[0] = 9 print a[0]
输出是 9
理由是:python 将常见类型的变量值做了引用,当b=a 时,实际上没有复制变量。
sys.getrefcount() 可以查看对某一值的引用次数
问题是:
为何要这么设计,这种设计在写代码的时候不会出现明显的bug么?
比如我需要在某个list基础上进行一些修改,但是以后会同时用到修改前和修改后的list,代码该怎么写呢?
a = [1,3,5] b = a b[0] = 9 print a[0]
输出是 9
理由是:python 将常见类型的变量值做了引用,当b=a 时,实际上没有复制变量。
sys.getrefcount() 可以查看对某一值的引用次数
问题是:
为何要这么设计,这种设计在写代码的时候不会出现明显的bug么?
比如我需要在某个list基础上进行一些修改,但是以后会同时用到修改前和修改后的list,代码该怎么写呢?
为什么要这样设计,没有深入了解过。
复制一个list可以这样用:copied_list = original_list[:]
这里有更多相关说明:http://docs.python.org/library/copy.h...
4 回答4.4k 阅读✓ 已解决
4 回答3.8k 阅读✓ 已解决
1 回答3k 阅读✓ 已解决
3 回答2.1k 阅读✓ 已解决
1 回答4.5k 阅读✓ 已解决
1 回答3.8k 阅读✓ 已解决
1 回答2.8k 阅读✓ 已解决
这就是完全面向对象的设计,我对python了解不多,不过我估计数组在python里应该是一个对象,而对对象某个属性的赋值,是只会改变引用的对象的。比如在php里面
它会显示