当前位置: 首页 > 面试题库 >

Python类变量int vs数组

云宏儒
2023-03-14
问题内容

我正在研究Python类,并得出以下示例,其中两个看起来是静态类变量的变量在修改时具有不同的行为。

这里发生了什么?我的第一个直觉是引用发生了一些棘手的事情。

class Foo:
    a = []
    n = 0
    def bar(self):
            self.a.append('foo')
            self.n += 1

x = Foo()
print x.a, x.n    ([] 0)
x.bar()
print x.a, x.n    (['foo', 1])
y = Foo()
print y.a, y.n    (['foo', 0])
y.bar()
print y.a, y.n    (['foo', 'foo'], 1)

问题答案:

您是正确的-在Foo.a访问self.a实际访问的情况下Foo.a,该访问在的所有实例之间共享Foo。但是,当您进行更新时self.n+=实际上在self该阴影上创建了一个实例级变量Foo.n

>>> import dis
>>> dis.dis(Foo.bar)
  5           0 LOAD_FAST                0 (self)
              3 LOAD_ATTR                0 (a)
              6 LOAD_ATTR                1 (append)
              9 LOAD_CONST               1 ('foo')
             12 CALL_FUNCTION            1
             15 POP_TOP

  6          16 LOAD_FAST                0 (self)
             19 DUP_TOP             
             20 LOAD_ATTR                2 (n)
             23 LOAD_CONST               2 (1)
             26 INPLACE_ADD         
             27 ROT_TWO             
             28 STORE_ATTR               2 (n)
             31 LOAD_CONST               0 (None)
             34 RETURN_VALUE

换句话说,当您执行self.a.append('some value')此操作时,解释a器将通过名称on从内存中获取数据Foo,然后对Foo.a指向的列表进行变异。

另一方面,当您执行self.n += 1口译员时:

  • nFoo(因为它无法找到nself
  • 创建一个新的价值 n + 1
  • 将新值存储在的属性nself


 类似资料:
  • 问题内容: 我在下面的示例中进行了尝试,并需要进行澄清。在这两种情况下,我都可以在测试函数中访问类变量和实例。 因此,假设是否必须定义一个需要在所有函数中使用的文字,这将是定义..self变量或class变量的更好方法? code.py 问题答案: 类变量对于所有实例使用的“常量”非常有用(从技术上讲,所有方法都是如此)。您可以使用模块全局变量,但是使用类变量会使它与类更明确地关联。 您实际上也经

  • 问题内容: 下面的代码由于某种原因给我一个错误,有人可以告诉我这是什么问题。 基本上,我创建了2个Point&Circle类。Circle正在尝试继承Point类。 错误: 问题答案: 看起来您可能已经修复了原始错误,该错误是由错误消息所指示的,尽管您的修复稍有不正确,而不是应该使用的类。 请注意,在的方法中还有一个错误调用的地方: 这在Python 3上是有效的代码,但是在Python 2上需要

  • 问题内容: 我有Python类,在运行时我只需要一个实例,因此每个类只具有一个属性就足够了,而每个实例只具有一次属性就足够了。如果将有多个实例(不会发生),则所有实例应具有相同的配置。我想知道以下哪种选择更好或更“惯用”的Python。 类变量: 实例变量: 问题答案: 我有Python类,在运行时我只需要一个实例,因此每个类只具有一个属性就足够了,而每个实例只具有一次属性就足够了。如果将有多个实

  • 本文向大家介绍Python变量和数据类型详解,包括了Python变量和数据类型详解的使用技巧和注意事项,需要的朋友参考一下 Python 变量类型       变量存储在内存中的值。这就意味着在创建变量时会在内存中开辟一个空间。    基于变量的数据类型,解释器会分配指定内存,并决定什么数据可以被存储在内存中。    因此,变量可以指定不同的数据类型,这些变量可以存储整数,小数或字符。 变量赋值

  • 本文向大家介绍简单分析python的类变量、实例变量,包括了简单分析python的类变量、实例变量的使用技巧和注意事项,需要的朋友参考一下 1、类变量、实例变量概念 类变量: 类变量就是定义在类中,但是在函数体之外的变量。通常不使用self.变量名赋值的变量。类变量通常不作为类的实例变量的,类变量对于所有实例化的对象中是公用的。 实例变量: 实例变量是定义在方法中的变量,使用self绑定到实例上的

  • 问题内容: 在类中声明变量(在函数外部):所有类函数都可以访问它(基本上是公共变量) 在类内的函数内声明变量:只有该函数才能访问它(在该函数范围内) 在类内的函数内部声明带有self。(变量名)的变量:所有类函数都可以访问它(这与全局变量名有何不同?) 并且由于没有私有/受保护的事物,所以所有事物都是公共的,因此可以从类外部访问所有可以从类内部访问的事物。 我还有其他细微差别应该知道吗? 问题答案

  • 问题内容: 得知子类的类变量无法访问父类的类变量而没有特别指出父类的名称,我感到很惊讶: 为什么在定义By时我必须引用Ax,而不仅仅是x?这与我对实例变量的直觉是相反的,并且因为在定义B之后我可以引用Bx。 问题答案: 在Python中,在创建类之前,将在其自己的名称空间中执行类的主体(此后,该名称空间的成员将成为该类的成员)。因此,当解释器达到y = x + 1时,此时B类尚不存在,因此没有父类

  • 问题内容: 我知道我应该避免由于这样的混乱而首先使用全局变量,但是如果我要使用它们,以下是使用它们的有效方法吗?(我正在尝试调用在单独函数中创建的变量的全局副本。) 第二个函数使用的是否具有与使用和修改的的全局副本相同的值?定义后调用函数时,顺序重要吗? 问题答案: 如果你只想访问全局变量,则只需使用其名称即可。但是,要更改其值,你需要使用global关键字。 例如 这会将全局变量的值更改为55。