轉https://www.cnblogs.com/hzhuxin/p/4645070.html
我們在做項目時,前期寫的類中的一些代碼可能由於需求變化的原因需要重寫,有時重寫時方法的傳參和返回值也會發生變化,這樣往往導致調用的代碼也跟着出錯,我們看下spring的代碼是如何處理這樣的事,先看下面兩段代碼,上面這段是之前的getHandler方法,現在需要改成第二段代碼,方法的參數cache不要了,而且方法內部的實現肯定也變化了,spring框架的作者先是在之前的方法上加了@Deprecated標誌,然後讓舊的方法去調用新的方法,相當於舊方法起了個臨時代理的作用,這樣之前調舊gethandler方法的代碼也不會出問題,而實現已經切換成了新的實現,並且後面寫代碼的人看到了舊方法的@Deprecated標誌後,也會避免調用它,而直接選擇去調用新的getHandler方法。
@Deprecated
protected HandlerExecutionChain getHandler(HttpServletRequest request, boolean cache) throws Exception {
return getHandler(request);
}
protected HandlerExecutionChain getHandler(HttpServletRequest request) throws Exception {
for (HandlerMapping hm : this.handlerMappings) {
if (logger.isTraceEnabled()) {
logger.trace(
"Testing handler map [" + hm + "] in DispatcherServlet with name '" + getServletName() + "'");
}
HandlerExecutionChain handler = hm.getHandler(request);
if (handler != null) {
return handler;
}
}
return null;
}