1 Python多态介绍
对于习惯写c++等语言的程序员来说类多态,完全是靠接口多态继承实现的,具体体现在声明,就是在普通接口函数声明的前面多了一个关键字-virtual。 同样,对于面向对象的Python来说也是很类似的,就是在普通接口函数的前面多了一行声明(@classmethod)。这样看来c++的多态和Python类的多态只是语法差异上而已。
2 应用类举
假设让你设计并实现一套MapReduce流程(类似于大数据中的MapReduce),可已将其分解为IputData操作,Map操作和Reduce操作。
面对各种类型的数据输入方式,其读入数据的方式是不一样的,但是可以将其抽象成一个通用的读入数据的类,里面包含共同通用的方法。
class GenericInputData(object):
def read(self):
raise NotImplementedError
@classmethod
def generate_inputs(cls, config):
raise NotImplementedError
假设我们需要读入两种数据类型,一种是读入文件,另一种是读入网页,它们都继承于GenericInputData类,其定义如下:
class PathInputData(GenericInputData):
def __init__(self, path):
super(PathInputData, self).__init__()
self.path = path
def read(self):
return open(self.path).read()
def get_path_name