Python面向对象(一):对象的特征(实例属性,类属性,私有属性)

一、实例属性

1、实例属性是类实例化之后才会拥有的属性;
2、实例属性一般在__init__方法中创建,__init__方法在类实例化的时候被调用;
3、定义形式为:self.<属性名>,引用方法为:self.<属性名>(self代表类的实例本身);
4、在类外引用或者定义:实例名.属性名;
5、相同类的不同实例其实例属性是不相关的;
6、不建议在__init__方法之外创建和初始化实例属性;
7、不推荐在类外定义或者修改。

举例,分别对上面几点进行说明
class A:
    def __init__(self):
        self.aa = 1
        self.bb = 2
    def info(self):
        print("self.aa:",self.aa,"self.bb:",self.bb)

if __name__ == "__main__":
    a = A()#将类实例化,会调用__init__构造方法,创建实例属性self.aa,self.bb
    a.info()
    print(a.aa)#类外访问
    print(a.bb)
    b = A()#再实例化一个对象B
    b.aa = 3#类外重新定义
    a.info()
    b.info()
    print(a.aa)
    print(b.aa)
    a.cc = 6#类外定义实例属性(一般不这样做)
    print(a.cc)

输出为:

self.aa: 1 self.bb: 2
1
2
self.aa: 1 self.bb: 2
self.aa: 3 self.bb: 2
1
3

程序的大概构造是:创建了一个类A,在__init__构造方法中定义了两个实例属性aa和bb;info方法输出这两个实例属性。
主程序部分: 实例化了一个对象a;然后使用:“实例名. 方法名”的形式调用了实例方法info;a.aa是使用“实例名.属性名”的形式访问实例属性aa;接着又实例化了一个对象b,然后在类外使用“实例名.属性名”的形式重新定义了实例属性aa;然后调用两个实例化对象的info方法以及输出这两个实例化对象的实例属性。
程序输出部分可以看到,使用b.aa = 3在类外重新定义了实例属性之后,并没有影响实例a的实例属性(a.info()的输出还是1,2),所以相同类的不同实例其实例属性是不相关的。

二、类属性

1、类定义后就存在的属性,不需要实例化
2、相同类的不同实例可以公用类属性
3、类属性被改变时,作用范围是所有类的实例
4、访问方法:可以通过“类名.类属性名”的方法访问;也可以使用“实例名.类属性名”的方法访问(需要先实例化)

class A:
    cc = 0#类属性
    def __init__(self):
        self.aa = 1
        self.bb = 2
    def info(self):
        print("self.aa:",self.aa,"self.bb:",self.bb,"cc:",A.cc)

if __name__ == "__main__":
    a = A()#实例化一个对象a
    a.info()#调用实例方法
    print(A.cc)#直接使用类名.类属性名的方式访问
    print(a.cc)#使用实例名.类属性名的方式访问
    A.cc = 6#类外重新定义类属性
    b = A()#实例化一个对象b
    a.info()#类属性改变对a实例生效
    b.info()#类属性改变对b实例也生效

输出为:

self.aa: 1 self.bb: 2 cc: 0
0
0
self.aa: 1 self.bb: 2 cc: 6
self.aa: 1 self.bb: 2 cc: 6

三、私有属性(非强制性)

1、使用__(双下划线)开头的属性
2、使用_(单下划线)开头的属性
要注意的是:python语言并没有对这些属性设定强制性的访问限制,这些定义属性的定义方式,只是名义上的限制而非强制性。
双下划线开头的属性:

class A:
    def __init__(self):
        self.__ab = 0#定义私有属性__ab
    def info(self):
        print(self.__ab)#类的内部访问
if __name__ == "__main__":
    a = A()
    a.info()
    # print(a.__ab)#报错,类外不能访问
    print(a._A__ab)#类外可以通过这种形式访问

输出为:

0
0

单下划线开头的属性:

class A:
    def __init__(self):
        self._ab = 0#定义私有属性__ab
    def info(self):
        print(self._ab)#类的内部访问
if __name__ == "__main__":
    a = A()
    a.info()
    print(a._ab)#类外可以访问
    a._ab = 1#类外改变属性值
    a.info()
    print(a._ab)

输出为:

0
0
1
1

单下划线开头的属性类外可以访问以及修改

你可能感兴趣的:(Python面向对象(一):对象的特征(实例属性,类属性,私有属性))