代碼重構的技巧——合理使用@Deprecated


  最近由於工作環境不太理想,很長時間沒心情寫技術博文,今天在調試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;
    }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM