您会误解引用在Python中是如何工作的。在这里,所有名称都是引用,没有“值”。名称绑定到对象。但是
=不会修改名称所指向的对象,而是将名称重新绑定到其他对象:
x = 42y = x# now:# 'is' is a identity operator — it checks whether two names point to the# exact same objectprint x is y # => Trueprint x, y # 42 42y = 69# now y has been rebound, but that does not change the '42' object, nor rebinds xprint x is y # => Falseprint x, y # 42 69
要修改对象本身,它必须是可变的,即,公开对其进行了更改或具有可修改的字典的成员。当您重新绑定时,会发生与上述相同的事情
p-它完全没有关系
points,它只是修改了本地
p名称的含义。
如果要模拟类似C ++的引用,则需要将对象封装到可变容器中,例如列表。
reflect([points], 'X')# inside reflect:p[0] = ...
但是,至少在这种情况下,您不应该-应该只返回新对象。
points = reflect(points, 'X')# inside reflect, instead of p = ...return map(func, p)
好吧,既然我考虑了一下,您也可以
p[:] = map(func, p)
但是同样,返回新对象通常更好。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)