mirror of
https://github.com/rjNemo/design-patterns
synced 2026-06-12 13:36:41 +00:00
add code example
This commit is contained in:
parent
25b0820ac6
commit
ae8778f137
4 changed files with 85 additions and 0 deletions
15
behavioral/strategy/concrete_strategies.py
Normal file
15
behavioral/strategy/concrete_strategies.py
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
"""
|
||||||
|
Concrete Strategies implement the algorithm while following the base Strategy interface. The interface makes them
|
||||||
|
interchangeable in the Context.
|
||||||
|
"""
|
||||||
|
from behavioral.strategy.strategy import Strategy
|
||||||
|
|
||||||
|
|
||||||
|
class ConcreteStrategyA(Strategy):
|
||||||
|
def do_algorithm(self, data: list) -> list:
|
||||||
|
return sorted(data)
|
||||||
|
|
||||||
|
|
||||||
|
class ConcreteStrategyB(Strategy):
|
||||||
|
def do_algorithm(self, data: list) -> list:
|
||||||
|
return reversed(sorted(data))
|
||||||
40
behavioral/strategy/context.py
Normal file
40
behavioral/strategy/context.py
Normal file
|
|
@ -0,0 +1,40 @@
|
||||||
|
from behavioral.strategy.strategy import Strategy
|
||||||
|
|
||||||
|
|
||||||
|
class Context:
|
||||||
|
"""
|
||||||
|
The Context defines the interface of interest to clients.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, strategy: Strategy):
|
||||||
|
"""
|
||||||
|
Usually, the Context accepts a strategy through the constructor, but also provides a setter to change it at
|
||||||
|
runtime.
|
||||||
|
"""
|
||||||
|
self._strategy = strategy
|
||||||
|
|
||||||
|
@property
|
||||||
|
def strategy(self):
|
||||||
|
"""
|
||||||
|
The Context maintains a reference to one of the Strategy objects. The
|
||||||
|
Context does not know the concrete class of a strategy. It should work
|
||||||
|
with all strategies via the Strategy interface.
|
||||||
|
"""
|
||||||
|
return self._strategy
|
||||||
|
|
||||||
|
@strategy.setter
|
||||||
|
def strategy(self, strategy: Strategy):
|
||||||
|
"""
|
||||||
|
Usually, the Context allows replacing a Strategy object at runtime.
|
||||||
|
"""
|
||||||
|
self._strategy = strategy
|
||||||
|
|
||||||
|
def do_some_business_logic(self) -> None:
|
||||||
|
"""
|
||||||
|
The Context delegates some work to the Strategy object instead of implementing multiple versions of the
|
||||||
|
algorithm on its own.
|
||||||
|
"""
|
||||||
|
|
||||||
|
print("Context: Sorting data using the strategy (not sure how it'll do it)")
|
||||||
|
result = self._strategy.do_algorithm(["a", "b", "c", "d", "e"])
|
||||||
|
print(",".join(result))
|
||||||
15
behavioral/strategy/main.py
Normal file
15
behavioral/strategy/main.py
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
"""
|
||||||
|
The client code picks a concrete strategy and passes it to the context.
|
||||||
|
The client should be aware of the differences between strategies in order to make the right choice.
|
||||||
|
"""
|
||||||
|
from behavioral.strategy.concrete_strategies import ConcreteStrategyA, ConcreteStrategyB
|
||||||
|
from behavioral.strategy.context import Context
|
||||||
|
|
||||||
|
context = Context(ConcreteStrategyA())
|
||||||
|
print("Client: Strategy is set to normal sorting.")
|
||||||
|
context.do_some_business_logic()
|
||||||
|
print()
|
||||||
|
|
||||||
|
print("Client: Strategy is set to reverse sorting.")
|
||||||
|
context.strategy = ConcreteStrategyB()
|
||||||
|
context.do_some_business_logic()
|
||||||
15
behavioral/strategy/strategy.py
Normal file
15
behavioral/strategy/strategy.py
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
from abc import ABC, abstractmethod
|
||||||
|
|
||||||
|
|
||||||
|
class Strategy(ABC):
|
||||||
|
"""
|
||||||
|
The Strategy interface declares operations common to all supported versions
|
||||||
|
of some algorithm.
|
||||||
|
|
||||||
|
The Context uses this interface to call the algorithm defined by Concrete
|
||||||
|
Strategies.
|
||||||
|
"""
|
||||||
|
|
||||||
|
@abstractmethod
|
||||||
|
def do_algorithm(self, data: list):
|
||||||
|
pass
|
||||||
Loading…
Reference in a new issue