dart_in_action/26_design_pattern_chain_of_...

97 lines
2.6 KiB
Dart
Raw Permalink Normal View History

2019-03-27 10:55:27 +08:00
/**
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;
}
}