一、实例属性
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
单下划线开头的属性类外可以访问以及修改