博客
关于我
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/

你可能感兴趣的文章
MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump备份时忽略某些表
查看>>
mysqlreport分析工具详解
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中null和空字符串的区别与问题!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
mysql中实现rownum,对结果进行排序
查看>>