我們在很多地方都能看到代表參數意義的符號${},可能我們在寫一些框架的時候,有時候也需要用到這個符號,但他們是如何精確解析的?或者說需要我們自已寫的時候,如何寫?我們先來看以下的幾個場景:
1.字符串"a${a}a"
2.字符串"a\${a}a"
3.字符串"a${a\}a"
4.字符串"a${a\}a}a"
5.字符串"a${a}a${"
6.字符串"a${a}a${a}"
以上幾個字符串中,基本上包括了使用的一些場景,所以我們在解析的時候,要把各種情況都考慮清楚,盡量的做到全面,這樣我們的框架才有意義。
很顯然,我們都會采用正則來解析,於是我們來新建一個JAVA正則的類:
public class RegExp { public boolean match(String reg, String str) { return Pattern.matches(reg, str); } public List<String> find(String reg, String str) { Matcher matcher = Pattern.compile(reg).matcher(str); List<String> list = new ArrayList<String>(); while (matcher.find()) { list.add(matcher.group()); } return list; } public List<String> find(String reg, String str, int index) { Matcher matcher = Pattern.compile(reg).matcher(str); List<String> list = new ArrayList<String>(); while (matcher.find()) { list.add(matcher.group(index)); } return list; } public String findString(String reg, String str, int index) { String returnStr = null; List<String> list = this.find(reg, str, index); if (list.size() != 0) returnStr = list.get(0); return returnStr; } public String findString(String reg, String str) { String returnStr = null; List<String> list = this.find(reg, str); if (list.size() != 0) returnStr = list.get(0); return returnStr; } public static void main(String[] args) { RegExp re = new RegExp(); System.out.println(re.find("(a)b", "ababab", 1)); } }
然后開始來解析了,很簡單,一個正則即可:
public class ParseKeyword { public List<String> getKeywords(String p){ String reg = "(?<=(?<!\\\\)\\$\\{)(.*?)(?=(?<!\\\\)\\})"; RegExp re = new RegExp(); List<String> list = re.find(reg, p); return list; } public static void main(String[] args) { ParseKeyword p = new ParseKeyword(); System.out.println(p.getKeywords("a${a}a")); System.out.println(p.getKeywords("a\\${a}a")); System.out.println(p.getKeywords("a${a\\}a")); System.out.println(p.getKeywords("a${a\\}a}a")); System.out.println(p.getKeywords("a${a}a${")); System.out.println(p.getKeywords("a${ab}a${a}")); } }
總結一下:解析這個參數符號,要掌握的主要是正則,其中尤其以預查模式(歡迎訪問我的一篇關於預查模式的博客),然后其它的就是一些字符串的操作方法了。
希望能對大家有用。