python对象继承

继承允许我们在两个或者更多的类之间创建一种“是一个”的关系,这种关系把共同的细节抽象到一个超类里。

从技术上讲,每一个我们创建的类都使用了继承,所有的python类都是一个叫做object的特殊类的子类,如果我们不具体指明我们的类从其他类继承,那这个类自动从object继承过来。通过如下的语法,我们可以公开声明我们的类从object继承:

class MySubClass(object):
    pass

其中,object就是父类或者说是超类。MySubClass是子类。可以说是子类来源于父类,或者说是子类扩展了父类。

class Contact:
    all_contacts = []
  
    def __init__(self, name, email):
        self.name = name
        self.email = email
        Contact.all_contacts.append(self)

上面的例子中介绍了类变量,all_contacts的列表,它属于类定义中的一部分,会被这个类所有的实例共享。这里只有一个Contact.all_contacts列表,如果我们在任何一个对象调用self.all_contacts,他会引用这个列表。在初始化函数里面创建了一个新的contact类,这个列表会自动把这个对象添加进来。要小心这种用法,因为如果曾经使用self.all_contacts给这个变量赋值,那么将会在这个对象里面创建一个新的实例变量,这个类变量将会保持不变并且可以通过Contact.all_contacts访问到。

如果需要在联系人中添加供应商信息,则如下:

class Supplier(Contact):
    def order(self, order):
        print("If this were a real system we would send "
                 "{} order to {}".format(order, self.name))

将上述的两端代码保存为脚本,然后使用python -i导入这个脚本,在交互的解释器中执行如下的语句

$ python -i order.py 
>>> c = Contact("Some Body", "somebody@example.net")
>>> s = Supplier("Supplier", "supplier@example.net")
>>> print(c.name, c.email, s.name, s.email)
Some Body somebody@example.net Supplier supplier@example.net
>>> c.all_contacts
[<__main__.Contact object at 0x106eeefd0>, <__main__.Supplier object at 0x106f0f048>]
>>> c.all_contacts[0]
<__main__.Contact object at 0x106eeefd0>
>>> c.all_contacts[0].name
'Some Body'
>>> c.all_contacts[1].name
'Supplier'
>>> c.all_contacts[1].email
'supplier@example.net'
>>> c.all_contacts[0].email
'somebody@example.net'
>>> c.order("I need pliers")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'Contact' object has no attribute 'order'
>>> s.order("I need pliers")
If this were a real system we would send I need pliers order to Supplier
>>> 

 那么现在我们的Supplier类可以做任何Contact类可以做的事情,包括把自己添加到all_contacts这个列表中,和一个供应商需要处理的所有特殊的事情。这就是继承的魅力。

 

参考:

1、《Python3 面向对象编程》 [加]Dusty Philips 著

posted @ 2017-12-28 15:50  anovana  阅读(955)  评论(0编辑  收藏  举报