Python——面向对象高级编程

一、MethodType()

>>> from types import MethodType
  1. 公共代码部分:

     #!/usr/bin/python2.7
     from types import MethodType
     #创建一个函数
     def set_age(self, age):
      self.age=age
     #创建一个类
     class Student(object):
      pass
    
  2. 将set_age方法绑定到对象上: MethodType(set_age,s1,Student)MethodType(set_age,s1)
    第一个参数是要绑定的方法,第二个参数是要绑定的对象,第三个参数是类名(可省略)

     s1=Student()
     s1.set_age=MethodType(set_age,s1,Student)
     s1.set_age(23)
     print s1.age
     #输出23
     s2=Student()
     s2.set_age(24)
     print s2.age
     #报错,因为s2没有属性age
    

    set_age只是绑定在了s1上,而不是绑定在Student类上,所以这相当于s1自己私有的。

  3. set_age方法绑定到类上(没有None参数):
    Student.set_age=MethodType(set_age,Student),不传入None参数的时候,所有的实例会共用一份。

    Student.set_age=MethodType(set_age,Student)
    s1=Student()
    s2=Student()
    s1.set_age(20)
    s2.set_age(30)
    print s1.age
    # 输出30,而不是20
    print s2.age
    # 输出30
    
  4. set_age方法绑定到类上(第二个参数为None):
    Student.set_age=MethodType(set_age,None,Student),有参数None时,set_age就不是共享函数了,每个实例自有一份。

     Student.set_age=MethodType(set_age,None,Student)
     s1=Student()
     s2=Student()
     s1.set_age(20)
     s2.set_age(30)
     print s1.age
     #输出20
     print s2.age
     #输出30
    

    二、使用__slots__

    在动态绑定属性时,达到加以限制的目的

    class Student(object):

     __slots__ = ('name', 'age') # 用tuple定义允许绑定的属性名称
    

    当某属性不在__slots__tuple中时,就不能被绑定,否则将得到AttributeError的错误。

     >>> s = Student() # 创建新的实例
     >>> s.name = 'Michael' # 绑定属性'name'
     >>> s.age = 25 # 绑定属性'age'
     >>> s.score = 99 # 绑定属性'score'
     Traceback (most recent call last):
       File "<stdin>", line 1, in <module>
     AttributeError: 'Student' object has no attribute 'score'
    

需要注意的是,__slots__定义的属性仅对当前类实例起作用,对继承的子类是不起作用的。

除非在子类中也定义__slots__,这样,子类实例允许定义的属性就是自身的__slots__加上父类的__slots__

三、使用@property

相当于把一个私有属性的get或set函数合并成一个“假属性”来操作。
class Student(object):

    @property
    def score(self):
        return self._score
@score.setter
def score(self, value):
    if value &lt; 0 or value &gt; 100:
        raise ValueError('score must between 0 ~ 100!')
    self._score = value

_score是类Student的一个私有属性,@property下边是get方法,@score.setter是set方法,设置好后,可以把score这个函数看做一个变量:

>>> s = Student()
>>> s.score = 60 # 实际转化为s.set_score(60)
>>> s.score # 实际转化为s.get_score()
60
>>> s.score = 9999
ValueError: score must between 0 ~ 100!

当不设置@score.setter时,是个可读不可写的属性。

四、多重继承

通过多重继承,一个子类就可以同时获得多个父类的所有功能。

# -*- coding: utf-8 -*-
class Animal(object):
    pass
class Friend(object):
    pass
class Dog(Animal,Friend):
    pass

MixIn: 一种设计模式(待补)

其它博客链接:

  1. 变量和数据类型
  2. list和tuple
  3. 条件语句和循环
  4. dict和set
  5. 函数
  6. 切片+迭代+生成器
  7. 生成器和迭代器
  8. 函数式编程
  9. 模块
  10. 面向对象编程
  11. 面向对象高级编程
  12. 定制类
  13. 枚举类和元类
  14. 错误及处理
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值