描述符协议

class Grade:
    def __init__(self):
        self._value = 0
    def __get__(self, instance, owner):
        return self._value

    def __set__(self, instance, value):
        if not (0 <= value <= 100):
            raise ValueError('Grad must be 0 and 100')
        self._value = value

class Exam:
    math_grad = Grade()
    writting_grad = Grade()
    science_grad = Grade()


first_exam = Exam()
second_exam = Exam()
first_exam.writting_grad = 92
first_exam.math_grad = 80
#所有的Exam实例都要共享同一份Grade实例, 当程序定义Exam类的时候,他会把Grade实例构件好,以后创建Exam实例,就不在构件Grad
second_exam.math_grad = 100
#first_exam.science_grad = 120
print('writing', first_exam.writting_grad)
print('math', first_exam.math_grad)
print('second', second_exam.math_grad)
#print('science', first_exam.science_grad)

#把每个Exam实例多对应的值得记录到Grade中
class Grade:
    def __init__(self):
        self._value = {}
    def __get__(self, instance, owner):
        if instance is None: return self
        return self._value.get(instance, 0)
    def __set__(self, instance, value):
        if not (0 <= value <= 100):
            raise ValueError('Grade must be between 0 and 100')
        self._value[instance] = value

class Exam(object):
    math_grade = Grade()
    writing_grade = Grade()
    science_grade = Grade()

first_exam = Exam()
first_exam.writting_grad = 82
second_exam = Exam()
second_exam.writing_grade = 72
# print('writing1', first_exam.writting_grad)
# print('writing2', second_exam.writting_grad)

#这样会造成内存泄漏,解决办法是WeakKeyDictionary
from weakref import WeakKeyDictionary
class Grade2(object):
    def __init__(self):
        self._value = WeakKeyDictionary()
    def __get__(self, instance, owner):
        if instance is None: return self
        return self._value.get(instance, 0)
    def __set__(self, instance, value):
        if not (0 <= value <= 100):
            raise ValueError('Grade must be between 0 and 100')
        self._value[instance] = value

class Exam(object):
    math_grade = Grade2()
    writing_grade = Grade2()
    science_grade = Grade2()

first_exam = Exam()
first_exam.writing_grade = 82
second_exam = Exam()
second_exam.writing_grade = 72
print('writing1', first_exam.writing_grade)
print('writing2', second_exam.writing_grade)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值