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

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;
    }

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章