java中字符串参数化符号${}的解析
前言
我们在很多地方都能看到代表参数意义的符号${},可能我们在写一些框架的时候,有时候也需要用到这个符号,但他们是如何精确解析的?或者说需要我们自已写的时候,如何写?
我们先来看以下的几个场景:
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正则的类:
publicclassRegExp{
publicbooleanmatch(Stringreg,Stringstr){
returnPattern.matches(reg,str);
}
publicList<String>find(Stringreg,Stringstr){
Matchermatcher=Pattern.compile(reg).matcher(str);
List<String>list=newArrayList<String>();
while(matcher.find()){
list.add(matcher.group());
}
returnlist;
}
publicList<String>find(Stringreg,Stringstr,intindex){
Matchermatcher=Pattern.compile(reg).matcher(str);
List<String>list=newArrayList<String>();
while(matcher.find()){
list.add(matcher.group(index));
}
returnlist;
}
publicStringfindString(Stringreg,Stringstr,intindex){
StringreturnStr=null;
List<String>list=this.find(reg,str,index);
if(list.size()!=0)
returnStr=list.get(0);
returnreturnStr;
}
publicStringfindString(Stringreg,Stringstr){
StringreturnStr=null;
List<String>list=this.find(reg,str);
if(list.size()!=0)
returnStr=list.get(0);
returnreturnStr;
}
publicstaticvoidmain(String[]args){
RegExpre=newRegExp();
System.out.println(re.find("(a)b","ababab",1));
}
}
然后开始来解析了,很简单,一个正则即可:
publicclassParseKeyword{
publicList<String>getKeywords(Stringp){
Stringreg="(?<=(?<!\\\\)\\$\\{)(.*?)(?=(?<!\\\\)\\})";
RegExpre=newRegExp();
List<String>list=re.find(reg,p);
returnlist;
}
publicstaticvoidmain(String[]args){
ParseKeywordp=newParseKeyword();
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}"));
}
}
解析这个参数符号,要掌握的主要是正则,其中尤其以预查模式(推荐一篇预查模式的文章),然后其它的就是一些字符串的操作方法了。
总结
以上就是这篇文章的全部内容改了,希望本文的内容能对大家有用,如果有疑问大家可以留言交流。