责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。
优点: 1、降低耦合度。它将请求的发送者和接收者解耦。 2、简化了对象。使得对象不需要知道链的结构。 3、增强给对象指派职责的灵活性。通过改变链内的成员或者调动它们的次序,允许动态地新增或者删除责任。 4、增加新的请求处理类很方便。
缺点: 1、不能保证请求一定被接收。 2、系统性能将受到一定影响,而且在进行代码调试时不太方便,可能会造成循环调用。 3、可能不容易观察运行时的特征,有碍于除错。
使用场景:** 1、有多个对象可以处理同一个请求,具体哪个对象处理该请求由运行时刻自动确定。 2、在不明确指定接收者的情况下,向多个对象中的一个提交一个请求。 3、可动态指定一组对象处理请求。
代码
实现一个日志记录器
AbstractLogger是抽象的记录类
ConsoleLogger,FileLogger,ErrorLogger是具体的实现类
from __future__ import annotations
from abc import ABCMeta, abstractmethod
class AbstractLogger(metaclass=ABCMeta):
INFO = 1
DEBUG = 2
ERROR = 3
def __init__(self, level):
self.next_logger = None
self.level = level
@abstractmethod
def writer(self, message):
pass
def set_next_logger(self, next_logger: AbstractLogger):
self.next_logger = next_logger
def log_message(self, level, message):
if self.level >= level:
self.writer(message)
elif self.next_logger is not None:
self.next_logger.log_message(level, message)
class ConsoleLogger(AbstractLogger):
def writer(self, message):
print(f"Standard Console::Logger: {message}")
class FileLogger(AbstractLogger):
def writer(self, message):
print(f"File::Logger: {message}")
class ErrorLogger(AbstractLogger):
def writer(self, message):
print(f"Error Console::Logger: {message}")
class ChainPatternDemo:
@staticmethod
def get_chain_of_loggers():
error_logger = ErrorLogger(AbstractLogger.ERROR)
file_logger = FileLogger(AbstractLogger.DEBUG)
console_logger = ConsoleLogger(AbstractLogger.INFO)
error_logger.set_next_logger(file_logger)
file_logger.set_next_logger(console_logger)
return error_logger
if __name__ == '__main__':
logger_chain = ChainPatternDemo().get_chain_of_loggers()
logger_chain.log_message(AbstractLogger.ERROR, '测试信息')
logger_chain.log_message(4, '测试INFO')