設(shè)計模式-模板方法模式

模板方法(Template Method)模式的定義:定義一個操作中的算法骨架驯用,而將算法的一些步驟延遲到子類中藕帜,使得子類可以不改變該算法結(jié)構(gòu)的情況下重定義該算法的某些特定步驟扛吞。它是一種類行為型模式.
其優(yōu)點有:

  • 封裝了不變部分迷捧,擴展可變部分袜爪。
  • 在父類中提取了公共的部分代碼,便于代碼復(fù)用垃它。
  • 部分方法是由子類實現(xiàn)的,因此子類可以通過擴展方式增加相應(yīng)的功能,符合開閉原則国拇。

模式結(jié)構(gòu)

模板方法模式包含以下主要角色:

  • 抽象類:負(fù)責(zé)給出一個算法的輪廓和骨架洛史。它由一個模板方法和若干個基本方法構(gòu)成。
  • 具體子類:實現(xiàn)抽象類中所定義的抽象方法和鉤子方法酱吝,它們是一個頂級邏輯的一個組成步驟也殖。

源碼導(dǎo)讀

模板方法模式一般以“XXXtemplate”這種方式來命名,像我們所熟知的JdbcTemplate 就是采用模板方法模式設(shè)計的务热。
我們先看不使用JdbcTemplate 是怎么查詢的:

        try{
            Class.forName("com.mysql.jdbc.Driver");
            connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "1234");
            String sql = "select nickname,comment,age from users";
            statement = connection.createStatement();
            ResultSet resultSet = statement.executeQuery(sql);
            List<Users> usersList = new ArrayList<>();
            while (resultSet.next()) {
                Users users = new Users();
                users.setNickname(resultSet.getString(1));
                users.setComment(resultSet.getString(2));
                users.setAge(resultSet.getInt(3));
                usersList.add(users);
            }
            return usersList;
        } catch (Exception e) {
            e.printStackTrace();
       
        } finally {
            try {
                if (null != statement) {
                    statement.close();
                }
                if (null != connection) {
                    connection.close();
                }
            } catch (SQLException e) {
                throw new RuntimeException(e);
            }
        }
        return null;

我們執(zhí)行一次sql總是這樣一個流程:加載驅(qū)動-》獲取連接-》執(zhí)行sql-》創(chuàng)建一個Statement-》獲得返回值忆嗜。對于這種固定步驟的功能,我們就可以考慮用模板方法模式來實現(xiàn)了崎岂。

JDBCTemplate繼承了基類JdbcAccessor和接口類JdbcOperation捆毫。在基類JdbcAccessor的設(shè)計中,對DataSource數(shù)據(jù)源進行管理和配置冲甘。在JdbcOperation接口中绩卤,定義了通過Jdbc操作數(shù)據(jù)庫的基本操作方法,而JdbcTemplate提供這些接口方法的實現(xiàn)损合,比如execute方法省艳、query方法、update方法等嫁审。
jdbcTemplate的核心方法是execute

public <T> T execute(StatementCallback<T> action) throws DataAccessException {
        Assert.notNull(action, "Callback object must not be null");

        Connection con = DataSourceUtils.getConnection(getDataSource());
        Statement stmt = null;
        try {
            Connection conToUse = con;
            if (this.nativeJdbcExtractor != null &&
                    this.nativeJdbcExtractor.isNativeConnectionNecessaryForNativeStatements()) {
                conToUse = this.nativeJdbcExtractor.getNativeConnection(con);
            }
            stmt = conToUse.createStatement();
            applyStatementSettings(stmt);
            Statement stmtToUse = stmt;
            if (this.nativeJdbcExtractor != null) {
                stmtToUse = this.nativeJdbcExtractor.getNativeStatement(stmt);
            }
            T result = action.doInStatement(stmtToUse); // 回調(diào)
            handleWarnings(stmt);
            return result;
        }
        catch (SQLException ex) {
            JdbcUtils.closeStatement(stmt);
            stmt = null;
            DataSourceUtils.releaseConnection(con, getDataSource());
            con = null;
            throw getExceptionTranslator().translate("StatementCallback", getSql(action), ex);
        }
        finally {
            JdbcUtils.closeStatement(stmt);
            DataSourceUtils.releaseConnection(con, getDataSource());
        }
    }

在模板方法模式中跋炕,類的方法被劃分為這幾類:模板方法(定義了算法的骨架,按某種順序調(diào)用其包含的基本方法)律适,基本方法(包括抽象方法辐烂,具體方法,鉤子方法)

這個execute 便是它的模板方法了捂贿。而getDataSource()便是在父類中已經(jīng)實現(xiàn)的基本方法纠修。

點擊關(guān)注我的博客

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市厂僧,隨后出現(xiàn)的幾起案子扣草,更是在濱河造成了極大的恐慌,老刑警劉巖颜屠,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辰妙,死亡現(xiàn)場離奇詭異,居然都是意外死亡甫窟,警方通過查閱死者的電腦和手機密浑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來粗井,“玉大人尔破,你說我怎么就攤上這事街图。” “怎么了懒构?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵餐济,是天一觀的道長。 經(jīng)常有香客問我痴脾,道長颤介,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任赞赖,我火速辦了婚禮滚朵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘前域。我一直安慰自己辕近,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布匿垄。 她就那樣靜靜地躺著移宅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪椿疗。 梳的紋絲不亂的頭發(fā)上漏峰,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天,我揣著相機與錄音届榄,去河邊找鬼浅乔。 笑死,一個胖子當(dāng)著我的面吹牛铝条,可吹牛的內(nèi)容都是我干的靖苇。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼班缰,長吁一口氣:“原來是場噩夢啊……” “哼贤壁!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起埠忘,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤脾拆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后莹妒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體假丧,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年动羽,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渔期。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡运吓,死狀恐怖渴邦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拘哨,我是刑警寧澤谋梭,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站倦青,受9級特大地震影響瓮床,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜产镐,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一隘庄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧癣亚,春花似錦丑掺、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至玻孟,卻和暖如春唆缴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背黍翎。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工面徽, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人玩敏。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓斗忌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親旺聚。 傳聞我的和親對象是個殘疾皇子织阳,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,843評論 2 354

推薦閱讀更多精彩內(nèi)容