“当看到一只鸟走起来像鸭子、游泳起来像鸭子、叫起来也像鸭子,那么这只鸟就可以被称为鸭子。”
我们并不关心对象是什么类型,到底是不是鸭子,只关心行为。
比如在python中,有很多file-like的东西,比如StringIO,GzipFile,socket。它们有很多相同的方法,我们把它们当作文件使用。
又比如list.extend()方法中,我们并不关心它的参数是不是list,只要它是可迭代的,所以它的参数可以是list/tuple/dict/字符串/生成器等.
鸭子类型在动态语言中经常使用,非常灵活,使得python不想java那样专门去弄一大堆的设计模式。
下面例子用duck typing来实现多态。
-
- class Duck:
- def quack(self):
- print "Quaaaaaack!"
-
- class Bird:
- def quack(self):
- print "bird imitate duck."
-
- class Doge:
- def quack(self):
- print "doge imitate duck."
-
- def in_the_forest(duck):
- duck.quack()
-
- duck = Duck()
- bird = Bird()
- doge = Doge()
- for x in [duck, bird, doge]:
- in_the_forest(x)
再举个栗子,
我们来hack输出流。
- import sys
-
- sys.stdout = open('stdout.log', 'a')
- print 'foo'
-
- sys.stdout = sys.__stdout__
- print 'bar'
这样就把输出流给写入到文件中去了。