Python的mixin模式

栏目: Python · 发布时间: 8年前

内容简介:Python的mixin模式

版权声明: 本文为博主原创文章,发表自Noogel’s notes。转载需向 我的邮箱 申请。

Mixin 是利用语言特性来简洁的实现组合模式,Python 中通过一定规范的多继承实现的。

使用时需要注意一下几点:

  • 类的单一职责
  • 对宿主类一无所知
  • 不存在对宿主类的方法调用,避免引入 MRO 查找顺序

如下例子,对于不同的 Mixin 类只负责实现自己的行为特征函数,然后 People 类继承这些特征,在自己的函数中使用这些特征。

#!/usr/bin/python
# coding: utf-8
"""
File: mixin_demo.py
Author: noogel <noogel@163.com>
Date: 2018-01-12 09:11
Description: mixin_demo
"""


class EatMixin(object):

    def eat(self):
        return "eat!"


class DrinkMixin(object):

    def drink(self):
        return "drink!"


class SleepMixin(object):

    def sleep(self):
        return "sleep!"


class People(EatMixin, DrinkMixin, SleepMixin):

    def __init__(self):
        print "People can ", self.eat()
        print "People can ", self.drink()
        print "People can ", self.sleep()


if __name__ == "__main__":
    print "Init people."
    people = People()
➜  dev-demo python mixin_demo.py 
Init people.
People can  eat!
People can  drink!
People can  sleep!

https://www.zhihu.com/question/20778853

如果此文章能给您带来小小的提升,不妨小额赞赏我一下,以鼓励我写出更好的文章!

Python的mixin模式

微信打赏

Python的mixin模式

支付宝打赏


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web应用漏洞侦测与防御

Web应用漏洞侦测与防御

Mike Shema / 齐宁、庞建民、张铮、单征 / 机械工业出版社 / 2014-8-20 / 69.00

本书由国际知名网络安全专家亲笔撰写,全面讲解如何预防常见的网络攻击,包括HTML注入及跨站脚本攻击、跨站请求伪造攻击、SQL注入攻击及数据存储操纵、攻破身份认证模式、利用设计缺陷、利用平台弱点、攻击浏览器和隐私等, 全书共8章:第1章介绍HTML5的新增特性及使用和滥用HTML5的安全考虑;第2章展示了如何只通过浏览器和最基本的HTML知识就可以利用Web中最常见的漏洞;第3章详细讲解CSR......一起来看看 《Web应用漏洞侦测与防御》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具