最近由於工作環境不太理想,很長時間沒心情寫技術博文,今天在調試springMVC的DispatcherSevlet類的代碼時,看到一處代碼且聯想到項目中程序員的一些做法,覺得有必要寫一下。
我們在做項目時,前期寫的類中的一些代碼可能由於需求變化的原因需要重寫,有時重寫時方法的傳參和返回值也會發生變化,這樣往往導致調用的代碼也跟着出錯,我們看下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; }