vscode调试C++程序
2026/4/15 3:38:09
“设计模式不是银弹,但它是你代码世界的地图。”——写给每一位渴望写出优雅、可维护代码的 Python 开发者
在 Python 这样一门灵活、动态、语法优雅的语言中,很多人误以为“设计模式是 Java 工程师的事”。但随着项目规模扩大、团队协作加深、系统复杂度提升,设计模式的重要性愈发凸显。
设计模式不是约束,而是经验的沉淀。它们帮助我们:
本文将带你系统梳理 Python 中最常用的设计模式,结合语言特性与实战案例,帮助你在实际开发中灵活运用这些“编程武器”。
设计模式大致可分为三类:
| 类型 | 作用说明 | 示例模式 |
|---|---|---|
| 创建型模式 | 关注对象的创建方式 | 单例、工厂、建造者、原型等 |
| 结构型模式 | 关注对象之间的组合与结构 | 适配器、装饰器、代理、组合等 |
| 行为型模式 | 关注对象之间的通信与职责分配 | 观察者、策略、命令、状态等 |
目的:确保一个类只有一个实例,并提供全局访问点。
Python 的模块天然就是单例的。
# config.pydb_connection=None# main.pyimportconfigdefget_db():ifconfig.db_connectionisNone:config.db_connection="连接数据库"returnconfig.db_connectiondefsingleton(cls):instances={}defwrapper(*args,**kwargs):ifclsnotininstances:instances[cls]=cls(*args,**kwargs)returninstances[cls]returnwrapper@singletonclassLogger:deflog(self,msg):print(f"[LOG]{msg}")目的:将对象的创建逻辑封装起来,解耦调用者与具体类的依赖。
classDog:defspeak(self):return"Woof!"classCat:defspeak(self):return"Meow!"defanimal_factory(kind):ifkind=="dog":returnDog()elifkind=="cat":returnCat()raiseValueError("Unknown animal type")animal=animal_factory("dog")print(animal.speak())# 输出:Woof!目的:定义一系列算法,将它们封装起来,并使它们可以互换。
defadd(x,y):returnx+ydefsub(x,y):returnx-ydefmul(x,y):returnx*y strategies={"add":add,"sub":sub,"mul":mul}defexecute(strategy,x,y):returnstrategies[strategy](x,y)print(execute("mul",3,4))# 输出:12目的:在不修改原始类的情况下,动态添加功能。
deflog(func):defwrapper(*args,**kwargs):print(f"调用函数:{func.__name__}")returnfunc(*args,**kwargs)returnwrapper@logdefgreet(name):print(f"Hello,{name}!")greet("Alice")目的:当一个对象状态发生变化时,自动通知依赖它的对象。
classSubject:def__init__(self):self._observers=[]defattach(self,obs):self._observers.append(obs)defnotify(self,msg):forobsinself._observers:obs.update(msg)classObserver:defupdate(self,msg):print(f"收到通知:{msg}")subject=Subject()subject.attach(Observer())subject.notify("数据更新啦!")目的:将一个类的接口转换成客户端期望的另一个接口。
classOldPrinter:defprint_text(self,text):print(f"[OldPrinter]{text}")classNewPrinter:defoutput(self,content):print(f"[NewPrinter]{content}")classPrinterAdapter:def__init__(self,printer):self.printer=printerdefprint_text(self,text):ifhasattr(self.printer,'print_text'):self.printer.print_text(text)else:self.printer.output(text)printer=PrinterAdapter(NewPrinter())printer.print_text("Hello, Adapter!")目的:将请求封装为对象,从而支持撤销、重做、日志等操作。
classCommand:defexecute(self):passclassLightOnCommand(Command):defexecute(self):print("灯打开了")classRemoteControl:def__init__(self):self._commands=[]defadd_command(self,cmd):self._commands.append(cmd)defrun(self):forcmdinself._commands:cmd.execute()remote=RemoteControl()remote.add_command(LightOnCommand())remote.run()我们以“任务调度器”为例,结合策略模式 + 命令模式 + 单例模式,实现一个可扩展、可配置的系统。
# task_base.pyclassTask:defrun(self):raiseNotImplementedError# tasks.pyfromtask_baseimportTaskclassEmailTask(Task):defrun(self):print("发送邮件任务执行中...")classBackupTask(Task):defrun(self):print("备份文件任务执行中...")# registry.pyclassTaskRegistry:_tasks={}@classmethoddefregister(cls,name,task_cls):cls._tasks[name]=task_cls@classmethoddefget(cls,name):returncls._tasks.get(name)# main.pyfromtasksimportEmailTask,BackupTaskfromregistryimportTaskRegistry TaskRegistry.register("email",EmailTask)TaskRegistry.register("backup",BackupTask)defrun_task(name):task_cls=TaskRegistry.get(name)iftask_cls:task=task_cls()task.run()else:print(f"任务{name}未注册")run_task("email")run_task("backup")functools、contextlib、abc等模块可辅助实现多种模式。