国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java中字符串參數(shù)化符號${}的解析

2019-11-26 13:14:31
字體:
供稿:網(wǎng)友

前言

我們在很多地方都能看到代表參數(shù)意義的符號${},可能我們在寫一些框架的時(shí)候,有時(shí)候也需要用到這個(gè)符號,但他們是如何精確解析的?或者說需要我們自已寫的時(shí)候,如何寫?

我們先來看以下的幾個(gè)場景:

      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}"

以上幾個(gè)字符串中,基本上包括了使用的一些場景,所以我們在解析的時(shí)候,要把各種情況都考慮清楚,盡量的做到全面,這樣我們的框架才有意義。

很顯然,我們都會(huì)采用正則來解析,于是我們來新建一個(gè)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)); }}

然后開始來解析了,很簡單,一個(gè)正則即可:

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}")); }}

解析這個(gè)參數(shù)符號,要掌握的主要是正則,其中尤其以預(yù)查模式(推薦一篇預(yù)查模式的文章),然后其它的就是一些字符串的操作方法了。

總結(jié)

以上就是這篇文章的全部內(nèi)容改了,希望本文的內(nèi)容能對大家有用,如果有疑問大家可以留言交流。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 宁国市| 加查县| 都匀市| 余姚市| 西乌| 溆浦县| 金乡县| 上思县| 宁夏| 耿马| 历史| 无棣县| 遂昌县| 清新县| 民权县| 隆子县| 霍山县| 安义县| 龙岩市| 铜川市| 常山县| 班玛县| 弥勒县| 灌南县| 儋州市| 达拉特旗| 三亚市| 广南县| 郓城县| 德钦县| 龙江县| 波密县| 朝阳区| 烟台市| 高陵县| 长兴县| 丘北县| 绍兴县| 芮城县| 察雅县| 都昌县|