亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis中parsing包的用法

發布時間:2021-06-29 13:51:30 來源:億速云 閱讀:189 作者:chen 欄目:大數據

這篇文章主要介紹“mybatis中parsing包的用法”,在日常操作中,相信很多人在mybatis中parsing包的用法問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mybatis中parsing包的用法”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

private final String openToken;

    private final String closeToken;

    private final TokenHandler handler;

    public GenericTokenParser(String openToken, String closeToken, TokenHandler tokenHandler) {
        this.openToken = openToken;
        this.closeToken = closeToken;
        this.handler = tokenHandler;
    }

    public String parse(String text) {
        StringBuilder builder = new StringBuilder();
        //如果傳入的字符串有值
        if (text != null && text.length() > 0) {
            //將字符串轉為字符數組
            char[] src = text.toCharArray();
            int offset = 0;
            //判斷openToken在text中的位置,注意indexOf函數的返回值-1表示不存在,0表示在在開頭的位置
            int start = text.indexOf(openToken, offset);
            // #{favouriteSection,jdbcType=VARCHAR}
            // 這里是循環解析參數,參考GenericTokenParserTest,比如可以解析${first_name} ${initial} ${last_name} reporting.這樣的字符串,里面有3個 ${}
            // 驗證start是否大于-1(亦即給定參數text中存在openToken子串),如果大于-1(開啟循環),驗證在給定text的start位置的前一位字符是否為"\"(反斜扛),如果是反斜杠,說明獲取到的參數被屏蔽了,我們需要去除這個反斜杠,并重新定位offset。當然如果不是反斜扛,說明參數正常
            while (start > -1) {
                // 判斷一下 ${ 前面是否是反斜杠,這個邏輯在老版的mybatis中(如3.1.0)是沒有的
                if (start > 0 && src[start - 1] == '\\') {
                    // the variable is escaped. remove the backslash.
                    // 新版已經沒有調用substring了,改為調用如下的offset方式,提高了效率
                    //如果text中在openToken前存在轉義符就將轉義符去掉。如果openToken前存在轉義符,start的值必然大于0,最小也為1
                    //因為此時openToken是不需要進行處理的,所以也不需要處理endToken。接著查找下一個openToken
                    builder.append(src, offset, start - offset - 1).append(openToken);
                    offset = start + openToken.length(); //重設offset
                } else {
                    // 獲取第一個匹配子串的末位位置end,如果end為-1,表示不存在closeToken,則獲取末位end之前的所有串,并重新定位offset為src數組長度,如果end值不是-1,說明text字符串中存在結束標記closeToken
                    int end = text.indexOf(closeToken, start);
                    //如果不存在openToken,則直接將offset位置后的字符添加到builder中
                    if (end == -1) {
                        builder.append(src, offset, src.length - offset);
                        offset = src.length; //重設offset
                    } else {
                        // 獲取開始標記之前的子串,并重新定位偏移量offset(start+開始標記的長度=具體參數開始位置),獲取這個參數串為content,然后調用TokenHandler的handleToken()方法對獲取到的參數串進行處理(比如替換參數之類),然后將處理后的串添加到之前的子串之上,再次重新定位偏移量offset為結束標記的下一位(end+closeToken的長度=end+1)
                        builder.append(src, offset, start - offset);
                        offset = start + openToken.length(); //重設offset
                        String content = new String(src, offset, end - offset);
                        // 得到一對大括號里的字符串后,調用handler.handleToken,比如替換變量這種功能
                        builder.append(handler.handleToken(content));
                        offset = end + closeToken.length(); //重設offset
                    }
                }
                // 獲取text中下一步openToken的開始位置,重置start,執行循環體第三步到第六步,處理每一個參數,直到最后一個參數,循環結束
                start = text.indexOf(openToken, offset);
            }
            // 驗證偏移量offset與src數組的長度,如果offset小,說明原串還有部分未添加到新串之上,將末尾剩余部分添加到新串,然后將新串返回,如果offset不小于src的數組長度,則直接返回新串
            if (offset < src.length) {
                builder.append(src, offset, src.length - offset);
            }
        }
        return builder.toString();
    }

到此,關于“mybatis中parsing包的用法”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武邑县| 朝阳县| 洪江市| 清镇市| 亚东县| 永靖县| 临夏市| 于田县| 唐河县| 仙游县| 无锡市| 前郭尔| 吉首市| 沧州市| 溆浦县| 额济纳旗| 延庆县| 南阳市| 富平县| 城固县| 岢岚县| 平邑县| 永胜县| 迁西县| 辉南县| 绥芬河市| 邻水| 越西县| 英德市| 鲁甸县| 若尔盖县| 同仁县| 隆德县| 陇川县| 富民县| 绵阳市| 邹城市| 祁东县| 南昌市| 中超| 邻水|