技术宅,fat-man

增加语言的了解程度可以避免写出愚蠢的代码

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

通过调试的重构代码(设计是对的,但是实现过程却有诸多的问题)

复制代码
#!/usr/bin/env python

class Processor:
    def __init__(self, processor):
        self.processor = processor
        
    def isAllowSend(self, message, setChargeFlag):
        pass

class WhildListProcessor(Processor):
    def isAllowSend(self, message, setChargeFlag):
        print "WhildListProcessor.isAllowSend is Running"
        if message.sender in (1,2):
            print "WhildListProcessor.isAllowSend return True"
            return True
        
        return self.processor.isAllowSend(message, setChargeFlag)

class DateProcessor(Processor):
    def isAllowSend(self, message, setChargeFlag):
        print "DateProcessor.isAllowSend is Running"
        if message.date > "20130101":
            print "DateProcessor.isAllowSend return False"
            return False
        
        return self.processor.isAllowSend(message, setChargeFlag)

class DefaultProcessor(Processor):
    def isAllowSend(self, message, setChargeFlag):
        print "DefaultProcessor.isAllowSend is Running"
        setChargeFlag(message)
        print "DefaultProcessor.isAllowSend return True"
        return True
    
def getProcessor():
    return WhildListProcessor(DateProcessor(DefaultProcessor(None)))

class Message:
    def __init__(self, sender):
        self.sender   = sender
        self.isSend   = False
        self.isCharge = False
        self.date     = "20110201"

def setChargeFlag(message):
    print "Set Charge Flag"
    message.isCharge = True

def setSendFlag(message):
    print "Set Send Flag"
    message.isSend = True

def run():
    message = Message(10)
    processor = getProcessor()
    if (processor.isAllowSend(message, setChargeFlag)):
        setSendFlag(message)
        
run()
复制代码

这是前一篇博客里的代码,通过实际调试之后的代码,下列的体会:

1,  设计是对的

2,  我在实现设计的过程里却有bug产生

  2,1 WhildListProcessor 等类的isAllowSend方法没有return

  2,2 DefaultProcessor没有继承我的Processor类

  2,3 既然增加了DateProcessor类并检查了Message.date属性,却没在Message类里增加date属性

  2,4 出现一个拼写错误 DefaultProcessor 写成 DefaltProcessor

 

实际上我的多数bug都是这么产生的,是我的性格太粗疏了吗? :( 另外,各位看官,这是一个设计模式,您看出来了吗

posted on   codestyle  阅读(542)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示