Python:将可变(?)对象传递给方法

nVi*_*Viz 4 python methods arguments object mutable

我正在尝试使用一个方法来实现一个类,该方法使用一个对象调用另一个方法,该对象是该类的一部分,其中最低的方法会改变该对象。我的实现有点复杂,所以我将发布一些虚拟代码,以便您可以看到我在说什么:

class test:
    def __init__(self,list):
        self.obj = list
    def mult(self, x, n):
        x = x*n
    def numtimes(self, n):
        self.mult(self.obj, n)
Run Code Online (Sandbox Code Playgroud)

现在,如果我创建这种类型的对象并运行 numtimes 方法,它不会更新 self.obj:

m = test([1,2,3,4])
m.numtimes(3)
m.obj  #returns [1,2,3,4]
Run Code Online (Sandbox Code Playgroud)

而我希望它给我 [1,2,3,4,1,2,3,4,1,2,3,4]

基本上,我需要将 self.obj 传递给 mult 方法并让它改变 self.obj ,这样当我调用 m.obj 时,我会得到 [1,2,3,4,1,2,3,4, 1,2,3,4] 而不是 [1,2,3,4]。

我觉得这只是理解 python 如何将对象作为参数传递给方法的问题(就像它制作对象的副本,而我需要使用指针),但也许不是。我是 python 新手,在这里确实需要一些帮助。

提前致谢!!

Ere*_*rez 6

请允许我讨论更大的可变性主题。

列表是可变对象,并且支持可变操作和不可变操作。这意味着就地更改列表的操作以及返回新列表的操作。相比之下,元组只是不可变的。

因此,要乘以列表,您可以选择两种方法:

  1. 一个 *= 乙

这是一个可变操作,它将就地更改“a”。

  1. a = a * b

这是一个不可变的操作。它将评估“a*b”,创建一个具有正确值的新列表,并将“a”分配给该新列表。

这里已经提供了解决您问题的方法。但是,我建议您继续阅读一下。当您将列表(和其他对象)作为参数传递时,您只是传递一个新的引用或指向同一列表的“指针”。因此,在该列表上运行可变操作也会更改您传递的列表。当您编写以下内容时,结果可能是一个非常微妙的错误:

>>> my_list = [1,2,3]
>>> t = test(my_list)
>>> t.numtimes(2)
>>> my_list
[1,2,3,1,2,3]  # Not what you intended, probably!
Run Code Online (Sandbox Code Playgroud)

这是我的最终建议。您可以选择使用可变操作,这很好。但然后根据您的参数创建一个新副本,如下所示:

def __init__(self,l):
    self.obj = list(l)
Run Code Online (Sandbox Code Playgroud)

或者使用不可变操作,并将它们重新分配给 self:

def mult(self, x, n):
    self.x = x*n
Run Code Online (Sandbox Code Playgroud)

或者两者都做,更加安全也没有什么坏处:)