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