python基础进阶:类属性和实例属性,__slots__方法
2021-01-08 本文已影响0人
孤城暮雨丶
本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理
本文章来自腾讯云 作者:我是李超人
私信小编回复01可领取学习资料以及学习视频
类属性和实例属性
python里面属性分两种,类属性和实例属性。如何去区分一个属性是类属性还是实例属性?在init中带有self的是实例属性,与方法平级的是类属性。
class Man(object):
gender = 'man'
def __init__(self, name, age):
self.name = name
self.age = age
def behavior(self):
print('hello')
def __str__(self):
return 'name = %s, age = %s'%(self.name, self.age)
这个案例里gender是类属性,name和age是实例属性 。类属性和实例属性在用途上有区别呢?
还是上面那个案例,做到如下操作:
man1 = Man('ric', 19)
man2 = Man('peter', 20)
# 第一步
Man.gender = 'women'
print(Man.gender)
print(man1.gender)
print(man2.gender)
# 第二步
man1.gender = 'man'
print(Man.gender)
print(man1.gender)
print(man2.gender)
# 第三步
Man.gender = 'unknow'
print(Man.gender)
print(man1.gender)
print(man2.gender)
# 第四步
Man.country = 'china'
print(Man.country)
print(man1.country)
print(man2.country)
# 第五步
man1.education = '本科'
print(man1.education)
print(man2.education)
print(Man.education)
第一步:
women
women
women
第二步:
women
man
women
第三步:
unknow
man
unknow
第四步:
china
china
china
第五步:
本科
在这里插入图片描述
在这里插入图片描述
dict方法
类属性和实例属性都可以通过dict来获取
print(Man.__dict__)
print(man1.__dict__)
输出:
{'__module__': '__main__', 'gender': 'unknow', '__init__': <function Man.__init__ at 0x000001AC9D29D820>, 'behavior': <function Man.behavior at 0x000001AC9D29DA60>, '__str__': <function Man.__str__ at 0x000001AC9D29DAF0>, '__dict__': <attribute '__dict__' of 'Man' objects>, '__weakref__': <attribute '__weakref__' of 'Man' objects>, '__doc__': None, 'country': 'china'}
{'name': 'ric', 'age': 19, 'gender': 'man'}
slots方法
默认情况下每个实例都会被分配一个dict用来保存实例属性,但是这样会浪费空间,可以通过slots属性来省去给实例分配dict。只有在slots中定义的属性名才能被实例添加为属性。且slots中的属性不能和类属性同名,不然会报冲突错误。
class Person(object):
__slots__ = ('country', 'education')
gender = 'man'
def __init__(self):
pass
per = Person()
per.country = 'china'
print(per.country)
per.address = 'beijing' # 错误:添加失败
print(per.address)
由于address属性不在slots中,所以给person实例添加address属性会失败。
有了slots方法后,实例属性只能通过slots来获取属性,类属依然可以通过dict方法来获取。
print(per.__slots__)
print(Person.__dict__)