博客
关于我
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的timestamp(时间戳)详解以及2038问题的解决方案
查看>>
mysql的util类怎么写_自己写的mysql类
查看>>
MySQL的xml中对大于,小于,等于的处理转换
查看>>
mysql的下载安装
查看>>
Mysql的两种存储引擎详细分析及区别(全)
查看>>
mysql的临时表简介
查看>>
MySQL的主从复制云栖社区_mysql 主从复制配置
查看>>
MySQL的事务隔离级别实战
查看>>
mysql的优化策略有哪些
查看>>
MySQL的使用
查看>>
mysql的全文检索的方法
查看>>
MySQL的函数
查看>>
mysql的函数DATE_ADD()
查看>>
mysql的函数操作
查看>>
mysql的分类排名_mysql高低排名
查看>>
Mysql的分表设计方法 (水平分表和垂直分表)
查看>>
mysql的分页查询limit关键字
查看>>
MySql的创建数据表、约束、外键约束的创建修改删除、级联操作
查看>>
MySQL的删除修改的实验目的_基础篇 - 数据库及表的修改和删除
查看>>
MySQL的四大隔离级别,你都知道哪些?
查看>>