Java使用正则匹配捕捉
1 Pattern p = Pattern.compile("name="sign" value="(.*)"/>");
2 Pattern p = Pattern.compile("name="sign" value=*"(.?)**"/>");
第二个比第一个多了一个?号,请问其中区别是什么
伊谢尔伦2017-04-18 10:57:01
貪欲な人とそうでない人の違い。
簡単に言うと、非貪欲とは、後に別の一致があるかどうかに関係なく、一致すると停止することを意味し、貪欲とは、後で一致がある限り停止しないことを意味します。
天蓬老师2017-04-18 10:57:01
正規表現に繰り返しを受け入れる修飾子が含まれている場合、通常の動作は、できるだけ多くの文字と一致します (式全体が一致する場合もあります)。次の式を例に挙げます: a.*b。これは、a で始まり b で終わる最長の文字列と一致します。これを使用して aabab を検索すると、文字列 aabab 全体と一致します。これを貪欲マッチングと呼びます。
場合によっては、遅延マッチング、つまりできるだけ少ない文字のマッチングが必要になることがあります。上記の修飾子は、後ろに疑問符 ? を追加することで遅延マッチング パターンに変換できます。このように、.*? は、任意の数の繰り返しをマッチングすることを意味しますが、全体のマッチングが成功するよう、最小限の繰り返しを使用します。次に、例の遅延バージョンを見てみましょう:
a.*?b は、a で始まり b で終わる最も短い文字列と一致します。 aabab に適用すると、aab (文字 1 ~ 3) と ab (文字 4 ~ 5) に一致します。
コピー元: http://deerchao.net/tutorials... 正規表現の 30 分入門、貪欲で怠惰な部分
高洛峰2017-04-18 10:57:01
この質問には、正規表現における貪欲モードと遅延モード (非貪欲モードとも呼ばれる) が含まれます
まず、これら 2 つの定義を見てみましょう
貪欲モードと最大マッチング*
,+
,'{n,}',.*
は両方とも貪欲モードです、いわゆる最大マッチングです。例を示します
怠惰モードでは、マッチングが成功することを前提として、できるだけ少ない回数でマッチングします。
引き続き上記の例: