当前位置: 首页 > news >正文

网站logo怎么替换中国seo谁最厉害

网站logo怎么替换,中国seo谁最厉害,做物流网站,站长统计app网站文章目录 一、责任链模式定义二、例子2.1 菜鸟教程2.1.1 定义一个抽象日志类2.1.2 定义日志类的具体实现类ConsoleLogger 、ErrorLogger 、FileLogger2.1.3 将日志类串起来,并使用 2.2 JDK源码——Filter2.3 Spring源码——HandlerInterceptor 三、其他设计模式 一、…

文章目录

  • 一、责任链模式定义
  • 二、例子
    • 2.1 菜鸟教程
      • 2.1.1 定义一个抽象日志类
      • 2.1.2 定义日志类的具体实现类ConsoleLogger 、ErrorLogger 、FileLogger
      • 2.1.3 将日志类串起来,并使用
    • 2.2 JDK源码——Filter
    • 2.3 Spring源码——HandlerInterceptor
  • 三、其他设计模式

一、责任链模式定义

类型: 行为型模式
每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,那么它会把相同的请求传给下一个接收者,依此类推。
目的: 职责链上的处理者负责处理请求,客户只需要将请求发送到职责链上即可,无须关心请求的处理细节和请求的传递,所以职责链将请求的发送者和请求的处理者解耦了。

个人理解:上面菜鸟教程说职责链将发送者和请求的处理者解耦,但个人觉得职责链更多的是将多个责任解耦,使用时将所需要的责任组织成责任链。

二、例子

2.1 菜鸟教程

菜鸟教程是以一个日志类为例子。

2.1.1 定义一个抽象日志类

public abstract class AbstractLogger {public static int INFO = 1;public static int DEBUG = 2;public static int ERROR = 3;protected int level;//责任链中的下一个元素protected AbstractLogger nextLogger;public void setNextLogger(AbstractLogger nextLogger){this.nextLogger = nextLogger;}public void logMessage(int level, String message){if(this.level <= level){write(message);}if(nextLogger !=null){nextLogger.logMessage(level, message);}}abstract protected void write(String message);}

2.1.2 定义日志类的具体实现类ConsoleLogger 、ErrorLogger 、FileLogger

public class ConsoleLogger extends AbstractLogger {public ConsoleLogger(int level){this.level = level;}@Overrideprotected void write(String message) {    System.out.println("Standard Console::Logger: " + message);}
}
public class ErrorLogger extends AbstractLogger {public ErrorLogger(int level){this.level = level;}@Overrideprotected void write(String message) {    System.out.println("Error Console::Logger: " + message);}
}
public class FileLogger extends AbstractLogger {public FileLogger(int level){this.level = level;}@Overrideprotected void write(String message) {    System.out.println("File::Logger: " + message);}
}

2.1.3 将日志类串起来,并使用

public class ChainPatternDemo {private 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;  }public static void main(String[] args) {AbstractLogger loggerChain = 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.");}
}

2.2 JDK源码——Filter

public interface Filter {default void init(FilterConfig filterConfig) throws ServletException {}void doFilter(ServletRequest var1, ServletResponse var2, FilterChain var3) throws IOException, ServletException;default void destroy() {}
}

2.3 Spring源码——HandlerInterceptor

public interface HandlerInterceptor {default boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {return true;}default void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {}default void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {}
}
public class HandlerExecutionChain {@Nullableprivate HandlerInterceptor[] interceptors;boolean applyPreHandle(HttpServletRequest request, HttpServletResponse response) throws Exception {HandlerInterceptor[] interceptors = getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for (int i = 0; i < interceptors.length; i++) {HandlerInterceptor interceptor = interceptors[i];if (!interceptor.preHandle(request, response, this.handler)) {triggerAfterCompletion(request, response, null);return false;}this.interceptorIndex = i;}}return true;}void applyPostHandle(HttpServletRequest request, HttpServletResponse response, @Nullable ModelAndView mv) throws Exception {HandlerInterceptor[] interceptors = getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for (int i = interceptors.length - 1; i >= 0; i--) {HandlerInterceptor interceptor = interceptors[i];interceptor.postHandle(request, response, this.handler, mv);}}}void triggerAfterCompletion(HttpServletRequest request, HttpServletResponse response, @Nullable Exception ex)throws Exception {HandlerInterceptor[] interceptors = getInterceptors();if (!ObjectUtils.isEmpty(interceptors)) {for (int i = this.interceptorIndex; i >= 0; i--) {HandlerInterceptor interceptor = interceptors[i];try {interceptor.afterCompletion(request, response, this.handler, ex);}catch (Throwable ex2) {logger.error("HandlerInterceptor.afterCompletion threw exception", ex2);}}}}
}

三、其他设计模式

创建型模式
结构型模式

  • 1、设计模式——装饰器模式(Decorator Pattern)+ Spring相关源码

行为型模式

  • 1、设计模式——访问者模式(Visitor Pattern)+ Spring相关源码
  • 2、设计模式——中介者模式(Mediator Pattern)+ JDK相关源码
  • 3、设计模式——策略模式(Strategy Pattern)+ Spring相关源码
  • 4、设计模式——状态模式(State Pattern)
  • 5、设计模式——观察者模式(Observer Pattern)+ Spring相关源码
  • 6、设计模式——备忘录模式(Memento Pattern)
  • 7、设计模式——模板方法模式(Template Pattern)+ Spring相关源码
  • 8、设计模式——迭代器模式(Iterator Pattern)+ Spring相关源码
http://www.ho-use.cn/article/2794.html

相关文章:

  • 城乡建设交通委员会网站短视频seo营销
  • 建个公司网站一年多少钱seo优化教程视频
  • 企业网站建设费用需要多少钱百度快照入口官网
  • wordpress 多色主题网站优化排名工具
  • 惠州关键词排名推广百度关键词优化查询
  • pc端宣传网站开发郑州发布最新通告
  • 专业柳州网站建设哪家便宜seo快速排名工具
  • 工业品公司做商城网站好吗网站制作定制
  • 深圳官网网站建设营销软文怎么写
  • 给别人做网站在那里接单百度推广怎么看关键词排名
  • 沈阳建设企业网站新媒体营销案例分析
  • 专门做销售培训的网站中国国家培训网靠谱吗
  • 全国建设网站福州seo网站排名
  • dwcs2018怎么做动态网站网站建设与管理就业前景
  • 做网站商城怎么样关键词优化和seo
  • 门窗网站制作宣传语baike seotl
  • 微信小程序怎么推广邯郸seo优化
  • 蓝田县住房与城乡建设局网站百度浏览器极速版
  • 擅自使用他人产品做网站宣传网站流量统计平台
  • 深圳企业网站哪家强seo实战培训学校
  • 企业网站建立费用 作什么科目广州百度快速排名优化
  • 平顶山建站公司北京网站优化步骤
  • 网页设计与制作课程标准电子版重庆网页优化seo公司
  • 网站开发建设成本百度云网页版登录入口
  • 建设通官方网站下载网络推广网站推广淘宝运营商
  • 做期货看哪些网站搜索引擎营销的实现方法
  • 线上营销的优势系统优化助手
  • 院系网站建设网站更换服务器对seo的影响
  • 企业网站mp4怎么处理上海网络公司seo
  • 上海市政府网站建设与对策分析四川seo多少钱