python设计模式六大原则

python设计模式六大原则

一.单一职责原则(SRP:Single responsibility principle)

一个类只负责一个功能领域中的相应职责,或者可以定义为:就一个类而言,应该只有一个引起它变化的原因。例如,搓衣板,既可以用来跪,也可以用来洗衣服。而在单一职责原理下,搓衣板的两个功能就是引起这个类变化的两个原因,就应该写成两个类

""" 单一职责原则 """


class Person(object):

    """ 人类 """

    def duty(self, one):

        """ Coder 的职责是写代码 ,农民就负责斗地主,其余的学习 """

        return one is "Coder" and "Coding" or one is "Farmer" and "Chinese poker" or "Studying"


if __name__ == '__main__':
    p = Person()
    print(p.duty("Coder"))

此时如果细分责任到每一个人,岂不是一堆的判断,肯定不科学,所以尽量让一个类或者一个模块做一件事

""" 单一职责原则 """


class Person(object):

    """ 人类 """

    def duty(self, one):

        """ Coder 的职责是写代码 ,农民就负责斗地主,其余的学习 """

        return one is "Coder" and "Coding" or one is "Farmer" and "Chinese poker" or "Studying"


class Coder(Person):

    """ 农民 """

    def duty(self):

        """ Coder 的职责是写代码 """

        return "Coding"


class Farmer(Person):

    """ 程序员 """

    def duty(self):

        """ 农民就负责斗地主 """

        return "Chinese poker"

if __name__ == '__main__':
    c = Coder()
    print(c.duty())
    f = Farmer()
    print(f.duty())

二. 里氏替换原则( LSP:Liskov Substitution Principle)

任何基类可以出现的地方,子类一定可以出现。 LSP是继承复用的基石,只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用,而衍生类也能够在基类的基础上增加新的行为

  • 子类必须完全实现父类的抽象方法,但不能覆盖父类的非抽象方法
  • 子类可以实现自己特有的方法
  • 当子类覆盖或实现父类的方法时,方法的前置条件(即方法的形参)要比父类方法的输入参数更宽松。
  • 当子类的方法实现父类的抽象方法时,方法的后置条件(即方法的返回值)要比父类更严格
  • 子类的实例可以替代任何父类的实例,但反之不成立
# -*- coding: utf-8 -*-
import abc
import time
""" 里氏替换原则 """
HOUR = 3600

class Person(object):

    """ 人类 """
    @abc.abstractmethod
    def duty(self):

        """ 职责 """
        pass


class Coder(Person):

    """ 程序员 """

    def duty(self):

        """ Coder 的职责是写代码 """

        return "Coding"

    def sleep(self):

        """ 有时睡5小时 """

        time.sleep(5*HOUR)


class Farmer(Person):

    """ 程序员 """

    def duty(self):

        """ 农民就负责斗地主 """

        return "Chinese poker"

    def sleep(self):

        """ 农民可以睡八小时 """

        time.sleep(8*HOUR)

三. 接口隔离原则(ISP)

接口隔离原则表明客户端不应该被强迫实现一些他们不会使用的接口,应该把胖接口中的方法分组,然后用多个接口代替他,每一个接口服务与一个子模块(与单一职责原则有类似的思想)

  • 一个类对另一个类的依赖性应当是建立在最小的接口上的。ISP还可以降低各个客户端之间的依赖性(低耦合)。
  • 客户端程序不应该依赖它不需要的接口方法,这就要求对接口进行细化,保证其纯洁性

在这里插入图片描述
通过使用接口隔离原则,本实例重构后的结构如图2所示
在这里插入图片描述

四. 开放-封闭原则(OCP)

实现开放-封闭原则的核心思想是对抽象编程,而不对具体编程,因为抽象相对稳定。让类依赖于固定的抽象,这样的修改是封闭的;而通过面向对象的继承和多态机制,可以实现对抽象体的继承,通过覆写其方法来改变固有行为,实现新的拓展方法,所以对于拓展是开放的。

  • 在设计方面充分利用“抽象”和“封装”思想。
    一方面是要在软件系统中找出各种可能的“可变因素”并将之封装起来
  • 在系统功能编程实现方面应用面向接口编程。
    当需求变化时,可以提供该接口新的实现类,以适应需求变化。
"""
开放封闭原则
"""
import abc

"""定义一个抽象的接口(接口是开放的)"""
class Process(metaclass=abc.ABCMeta):
    @abc.abstractmethod
    def process(self):
        """必须实现一个功能"""
        pass

"""实现对接口的拓展"""
"""解码功能"""
class Playerencode(Process):
    def process(self):
        return "encoding..."

"""输出流功能"""
class Playeroutput(Process):
    def process(self):
        return "ouputing..."

"""定义线程调度管理类"""
class PlayProcess(object):
    def __init__(self):
        self.message = None

    """判断某个对象或类是否继承于某个类"""
    def ischildof(self,obj, cls):
        try:
            for i in obj.__bases__:
                if i is cls or isinstance(i, cls):
                    return True
            for i in obj.__bases__:
                if self.ischildof(i, cls):
                    return True
        except AttributeError:  #当是对象时捕获的异常
            return self.ischildof(obj.__class__, cls)
        return False

    def callback(self,event):
        self.message = event.click()
        if self.ischildof(self.message,Process):
            return self.message.process()

"""实现一个MP4产品(产品功能是封闭的)"""
class Mp4(object):
    def work(self):
        playProcessOjb = PlayProcess()
        print(playProcessOjb.callback(Event("encode")))
        print(playProcessOjb.callback(Event("output")))
        
"""工厂类"""
class Event(object):
    def __init__(self,msg):
        self.__m = msg

    def click(self):  
        if self.__m == "encode":
            return Playerencode()
        elif self.__m == "output":
            return Playeroutput()

mp4 = Mp4()
mp4.work()

五. 依赖倒置原则(DIP)

每个接口中不存在子类用不到却必须实现的方法,如果不然就要将接口拆分,使用多个隔离的接口,比使用单个接口(多个接口方法集合到一个接口)。

  • 上层模块不应该依赖于下层模块,它们共同依赖于一个抽象类(父类不能依赖子类,它们都要依赖抽象类)
  • 抽象不能依赖具体,具体应该要依赖于抽象
  • 子类应该依赖于“抽象”而不应该依赖于某个实体对象

六. 迪米特法则(LoD)

低耦合,高内聚。无论是面向过程编程还是面向对象编程,只有使各个模块之间的耦合尽量的低,才能提高代码的复用率。低耦合的优点不言而喻,要做到低耦合,正是迪米特法则要去完成的。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 精通Python设计模式需要对Python编程语言有深入的理解,并且熟悉常用的设计模式设计模式是一种解决特定问题的经验总结,可以提供可复用的解决方案。 首先,精通Python设计模式需要掌握Python的基本语法和面向对象编程的概念。了解类、对象、继承、多态等概念并能够熟练运用。 其次,熟悉常用的设计模式设计模式可以分为创建型、结构型和行为型三大类。常见的设计模式包括单例模式、工厂模式、观察者模式、策略模式、装饰器模式等。对于每个模式,需要了解其定义、适用场景和解决的问题,同时能够根据具体的问题选择合适的模式。 此外,还需要能够在实际项目中运用设计模式。通过合理地运用设计模式,可以提高代码的可复用性和可扩展性,降低系统的维护成本。在使用设计模式时,需要根据具体的需求和情况进行权衡,避免过度设计和滥用设计模式。 最后,持续学习和实践是精通Python设计模式的关键。设计模式是一种经验,需要在实际开发中不断使用和改进。通过参与开源项目、阅读优秀代码和交流讨论等方式,不断提高自己的设计模式能力。 总之,精通Python设计模式需要熟悉Python语言并掌握常用的设计模式,能够在实际项目中灵活运用。通过不断学习和实践,可以进一步提高自己的设计模式水平。 ### 回答2: 精通Python设计模式是指对Python语言中各种设计模式及其应用有深入理解和熟练掌握的能力。 首先,精通Python设计模式需要对Python语言本身有较高的掌握程度,熟悉Python的语法、数据类型、面向对象编程等基础知识。同时,需要了解Python常用的模块和库,如NumPy、Pandas、TensorFlow等,在项目中熟练运用。 其次,要精通Python设计模式,需要对常见的设计模式有深入的理解。设计模式是对软件设计经验的总结和抽象,可以解决某类问题,并且能够提供可复用的设计方案。常见的设计模式有单例模式、工厂模式、观察者模式、装饰器模式等。对于每种设计模式,我们需要了解它的定义、适用场景、优缺点以及实际应用中的注意事项等。 最后,精通Python设计模式也需要具备实际项目经验。通过实践中运用设计模式解决具体问题,可以加深对设计模式的理解,并掌握如何将设计模式应用于实际项目中。同时,通过项目经验还可以锻炼解决问题的能力和代码质量。 总而言之,精通Python设计模式是掌握Python语言、了解常见设计模式、具备实际项目经验的综合能力。通过深入学习和实践,可以提高代码的可维护性、复用性和扩展性,从而更好地应对复杂的软件设计和开发任务。 ### 回答3: 精通Python设计模式是指对Python编程语言中各种设计模式的理解和运用达到了高级水平。 首先,理解设计模式的概念是基础。设计模式是在软件开发过程中用于解决常见问题和提供可复用解决方案的经验总结。在精通Python设计模式前,必须熟悉常见的设计模式分类,如创建型模式、结构型模式和行为型模式,并了解每个设计模式的特点和适用场景。 其次,精通Python设计模式需要掌握Python语言的特性和语法。熟练使用Python的面向对象编程(OOP)特性,如封装、继承和多态,能够更好地理解并实现设计模式。同时,熟悉Python中的函数式编程(FP)特性,如高阶函数、闭包和装饰器,能够更好地应用某些设计模式,如策略模式和装饰器模式。 其次,熟悉和掌握各种设计模式的具体实现和应用。例如,对于创建型模式中的工厂模式,可熟练使用Python的工厂函数或元类实现;对于结构型模式中的适配器模式,可使用Python的继承或组合方式实现;对于行为型模式中的观察者模式,可利用Python的事件机制或回调函数实现。 最后,精通Python设计模式还需要对代码的质量和可维护性有一定的追求。设计模式并非银弹,不应盲目使用。在实际开发中,需要根据具体情况权衡设计模式的利弊,并结合项目的需求和团队的能力做出合理的选择和折中。 总的来说,精通Python设计模式需要综合考虑设计模式的基本概念、Python语言的特性和语法以及具体应用场景的需求,通过不断实践和学习,不断提高自己的设计思维和编码能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值