最新公告
  • 欢迎您光临站盟网(原知事网),一个优质的网站源码基地、精品网站模板和插件。欢迎加入永久SVIP
  • python3类对象需要在init中初始化吗?

    正文概述 知事网   2020-11-16 11:11   335

    我们都知道类需要借助类对象才能使用,类对象的作用是不可缺少的。那么,在我们使用类对象的时候需要注意哪些细节呢?比如,有的小伙伴想知道init中需要初始化吗?这个问题不知道大家都考虑了没有,小编已经查阅了资料,找到了相关的答案,下面就分享给大家一起学习下吧。

    先看这段代码:

    class Cycle(object):
        def __init__(self,r):
            self.pi=3.1415926
            self.r=r
     
    a=Cycle(10)
    b=Cycle(7)

    首先,经常看到这样一个情况,为什么,我们通常定义的方法,为什么第一个参数需要是 self ,其实很简单,用来和具体实例绑定的。这一段代码,将 Cycle 实例化了两次,最后你输出 a.r 和 b.r 彼此的值是不一样的。那么实例变量的定义就很清晰了。

    那么什么是类变量呢?

    上面用 Cycle 这个类来描述一个圆。里面存在着一个变量 pi ,不同的圆,其 pi 值固定,那么我们可以将其抽象出来,诸多圆实例共享一个变量 pi

    class Cycle(object):
        pi=3.1415926
        def __init__(self,r):
            self.r=r
     
    a=Cycle(10)
    b=Cycle(7)

    那么为什么实例可以访问类变量呢?

    很简单,在我们调用具体变量的时候,遵循如下的查找规则

    1. 优先从实例中查找变量,如果没查找到执行 2

    2. 从类中查找变量,如果没查找到执行 3

    3. 按照继承链继续查找,直到找到或者到顶端没找到抛出异常为止

    首先代码是这样的

    class test:
        a=[1]*30
     
    x=test()
    x.a[1]=100
    y=test()
    print(y.a[1])

    我们来详细分析下首先声明了一个类变量a,值为list里面包含了30个元素然后实例化了一个实例 x接着执行 x.a[1]=100这一步发生了很多隐式的操作,我们慢慢讲首先,根据我们前面说的变量查找规则,在实例中没有查找到 a 这个变量后,然后向上到类里查找,诶!查找到了 a 这个 list ,紧接着,调用 list 中的方法 __setitem__ 来设置 list 中的第 2 个元素的值为 100 。诶?发现没有,我们这里,还是对类变量中的值进行修改了。好了重新复习下我们类变量的概念和类进行绑定的变量,该类的实例之间可以共享变量恩,在前面对类变量值进行修改了。然后类变量是被实例共享的,所以第二次实例化操作得到的实例 y 后,y.a[1] 得到的是不是我们修改后的值?

    好了,再看下一段代码

    class test:
        a=None
        def __init__(self):
            self.a=[1]*30
    x=test()
    x.a[1]=100
    y=test()
    print(y.a[1])

    在 __init__ 方法中,是不是声明了一个实例变量a,复习下我们实例变量的概念和实例绑定的变量,即实例变量,实例之间各自数据隔离,互不通用。和实例绑定的变量,实例之间彼此数据隔离,互不通用。那么两个实例 x,y 不管怎么修改,是不是只修改了和实例绑定的变量值,并不会影响其余实例的表现。

    看完文章的小伙伴相信已经知道答案了,还没找到答案的小伙伴再试试,如果实在还是不知道,可以私下跟小伙伴们讨论一下。

    转载自:python学习网 https://www.py.cn/


    站盟网 » python3类对象需要在init中初始化吗?

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者
    请选择支付方式
    ×
    支付宝支付
    微信支付
    余额支付
    ×
    微信扫码支付 0 元