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}")); } }
解析这个参数符号,要掌握的主要是正则,其中尤其以预查模式(推荐一篇预查模式的文章),然后其它的就是一些字符串的操作方法了。
总结
以上就是这篇文章的全部内容改了,希望本文的内容能对大家有用,如果有疑问大家可以留言交流。