7.5 抽象方法

抽象方法是定义在基类中可能有或没有任何实现的方法。Python中一个最简单的抽象方法类似这样:

class Pizza(object):
  @staticmethod
  def get_radius():
    raise NotImplementedError

任何继承自Pizza类的子类都需要实现并重写get_radius方法,否则调用这个方法会引发异常。

广告:个人专属 VPN,独立 IP,无限流量,多机房切换,还可以屏蔽广告和恶意软件,每月最低仅 5 美元

实现抽象方法的这种特定方式有一个缺陷:如果写一个继承自Pizza的类但忘了实现get_radius方法,那么只有在运行时调用这个方法时才会抛出错误,如示例7.11所示。

示例 7.11 实现一个抽象方法

>>> Pizza()
<__main__.Pizza object at 0x7fb747353d90>
>>> Pizza().get_radius()
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
 File "<stdin>", line 3, in get_radius
NotImplementedError

如果使用Python内置的abc模块(http://docs.python.org/2/library/abc.html)实现抽象方法,在试图实例化一个包含抽象方法的对象时会得到警告提示,如示例7.12所示。

示例 7.12 使用abc实现抽象方法

import abc
class BasePizza(object):
  __metaclass__ = abc.ABCMeta
  @abc.abstractmethod
  def get_radius(self):
     """Method that should do something."""

当使用abc以及它的特殊类时,如果试图实例化BasePizza或其未重写get_radius方法的子类,会得到TypeError

>>> BasePizza()
Traceback (most recent call last):
 File "<stdin>", line 1, in <module>
TypeError: Can't instantiate abstract class BasePizza with abstract methods
 get_radius

 注意

元类(metaclass)的声明在Python 2和Python 3之间产生了变化,因此前面的例子只适用于Python 2。