策略和实现的分离是一种设计模式,通常称为“策略模式”。这种模式允许在运行时选择算法的行为,使得算法的可变性独立于使用算法的客户端。以下是一个简单的Python示例,展示了如何实现策略模式。
假设我们有一个文本格式化程序,它可以将文本转换为大写或小写。我们定义一个策略接口(在Python中通常是一个抽象基类)和一个或多个具体策略来实现这个接口。
首先,我们定义策略接口:
from abc import ABC, abstractmethod
# 策略接口
class FormatStrategy(ABC):
@abstractmethod
def format(self, text):
pass
然后,我们实现具体策略:
# 具体策略A: 转换为大写
class UpperCaseStrategy(FormatStrategy):
def format(self, text):
return text.upper()
# 具体策略B: 转换为小写
class LowerCaseStrategy(FormatStrategy):
def format(self, text):
return text.lower()
接下来,我们创建一个上下文来使用这些策略:
class TextFormatter:
def __init__(self, strategy):
self._strategy = strategy
def set_strategy(self, strategy):
self._strategy = strategy
def format_text(self, text):
return self._strategy.format(text)
最后,我们使用这些策略:
# 创建上下文
text_formatter = TextFormatter(UpperCaseStrategy())
# 使用大写策略
print(text_formatter.format_text("hello world"))
# 切换到小写策略
text_formatter.set_strategy(LowerCaseStrategy())
print(text_formatter.format_text("HELLO WORLD"))
这个例子中,TextFormatter
是上下文,它接受一个 FormatStrategy
对象作为参数。通过改变传递给 TextFormatter
的策略,我们可以改变文本格式化的行为,而不需要修改格式化器的代码。这就是策略模式的好处:它允许你在运行时根据需要切换算法的实现,而不影响使用算法的客户端代码。