97 lines
2.6 KiB
Dart
97 lines
2.6 KiB
Dart
|
/**
|
|||
|
责任链模式(Chain of Responsibility Pattern)
|
|||
|
|
|||
|
意图:避免请求发送者与接收者耦合在一起,让多个对象都有可能接收请求,将这些对象连接成一条链,并且沿着这条链传递请求,直到有对象处理它为止。
|
|||
|
主要解决:职责链上的处理者负责处理请求,客户只需要将请求发送到职责链上即可,无须关心请求的处理细节和请求的传递,所以职责链将请求的发送者和请求的处理者解耦了。
|
|||
|
何时使用:在处理消息的时候以过滤很多道。
|
|||
|
如何解决:拦截的类都实现统一接口。
|
|||
|
*/
|
|||
|
main(List<String> args) {
|
|||
|
AbstractLogger loggerChain = LoggerFactory.getChainOfLoggers();
|
|||
|
|
|||
|
loggerChain.logMessage(AbstractLogger.INFO, "This is an information.");
|
|||
|
loggerChain.logMessage(
|
|||
|
AbstractLogger.DEBUG, "This is a debug level information.");
|
|||
|
loggerChain.logMessage(AbstractLogger.ERROR, "This is an error information.");
|
|||
|
}
|
|||
|
|
|||
|
//////////////////////////////////////////////////////////////////
|
|||
|
|
|||
|
///
|
|||
|
/// 创建抽象的记录器类
|
|||
|
///
|
|||
|
abstract class AbstractLogger {
|
|||
|
static int INFO = 1;
|
|||
|
static int DEBUG = 2;
|
|||
|
static int ERROR = 3;
|
|||
|
|
|||
|
int _level;
|
|||
|
|
|||
|
//责任链中的下一个元素
|
|||
|
AbstractLogger _nextLogger;
|
|||
|
|
|||
|
void setNextLogger(AbstractLogger nextLogger) {
|
|||
|
this._nextLogger = nextLogger;
|
|||
|
}
|
|||
|
|
|||
|
void logMessage(int level, String message) {
|
|||
|
if (this._level <= level) {
|
|||
|
write(message);
|
|||
|
}
|
|||
|
if (_nextLogger != null) {
|
|||
|
_nextLogger.logMessage(level, message);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
void write(String message);
|
|||
|
}
|
|||
|
|
|||
|
///
|
|||
|
/// 创建扩展了该记录器类的实体类
|
|||
|
///
|
|||
|
class ConsoleLogger extends AbstractLogger {
|
|||
|
ConsoleLogger(int level) {
|
|||
|
this._level = level;
|
|||
|
}
|
|||
|
|
|||
|
@override
|
|||
|
void write(String message) {
|
|||
|
print("Standard Console::Logger: $message");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
class ErrorLogger extends AbstractLogger {
|
|||
|
ErrorLogger(int level) {
|
|||
|
this._level = level;
|
|||
|
}
|
|||
|
|
|||
|
@override
|
|||
|
void write(String message) {
|
|||
|
print("Error Console::Logger: $message");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
class FileLogger extends AbstractLogger {
|
|||
|
FileLogger(int level) {
|
|||
|
this._level = level;
|
|||
|
}
|
|||
|
|
|||
|
@override
|
|||
|
void write(String message) {
|
|||
|
print("File::Logger: $message");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
class LoggerFactory {
|
|||
|
static AbstractLogger getChainOfLoggers() {
|
|||
|
AbstractLogger errorLogger = new ErrorLogger(AbstractLogger.ERROR);
|
|||
|
AbstractLogger fileLogger = new FileLogger(AbstractLogger.DEBUG);
|
|||
|
AbstractLogger consoleLogger = new ConsoleLogger(AbstractLogger.INFO);
|
|||
|
|
|||
|
errorLogger.setNextLogger(fileLogger);
|
|||
|
fileLogger.setNextLogger(consoleLogger);
|
|||
|
|
|||
|
return errorLogger;
|
|||
|
}
|
|||
|
}
|