博客
关于我
python小白实现对鸭子类型的简单模拟
阅读量:144 次
发布时间:2019-02-28

本文共 681 字,大约阅读时间需要 2 分钟。

本博文源于python基础,旨在对鸭子类型进行简单的模拟。

鸭子类型

所谓的鸭子类型就是根据对象的当前方法和属性集合决定,而不是根据继承自特定的类与接口设定。 在实际的程序设计中,通常不测试方法和函数中参数的类型,而是依赖文档、清晰的代码和测试来确保正确使用。

例子:模拟鸭子类型,实现对象的多态

实例模拟了鸭子、猫和树。因为树木没有这种叫的方法,因此它就会报错。

实验效果

在这里插入图片描述

实验代码

class Duck(object):    def __init__(self, name='duck'):        self.name = name    def quack(self):        print('嘎嘎嘎....')class Cat(object):    def __init__(self, name='cat'):        self.name = name    def quack(self):        print('喵喵喵....')class Tree(object):    def __init__(self, name='tree'):        self.name = namedef duck_demo(obj):    obj.quack()if __name__ == '__main__':    duck = Duck()    cat = Cat()    tree = Tree()    duck_demo(duck)    duck_demo(cat)    duck_demo(tree)

转载地址:http://jhrd.baihongyu.com/

你可能感兴趣的文章
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>