使用std::match_results::size() 決定正規表示式符合的大小
std::match_results::size()提供深入了解正規表示式匹配中的匹配組數量和完整匹配值。讓我們深入研究一下它的功能。
在 C 11 程式碼中,std::match_results::size() 用來取得正規表示式符合的資訊。它會傳回一個計數,其中包括整個匹配以及可能已在正規表示式中指定的任何捕獲組。但是,它提供的值可能與預期的匹配數不同。
請考慮以下範例:
<code class="cpp">std::string haystack("abcdefabcghiabc"); std::regex needle("abc"); std::smatch matches; std::regex_search(haystack, matches, needle); std::cout << matches.size() << std::endl;</code>
在這種情況下,您可能會預期會得到 3 個符合的結果。但是,您只會收到 1,因為 regex_search() 僅會擷取一個符合項目。 size() 函數報告捕獲組的計數加上整個匹配。
為了澄清,std::match_results 保存匹配詳細資訊和任何發現的子匹配。如果正規表示式搜尋成功,它不會為空。它包含一系列 sub_match 對象,第一個代表完全匹配。 match_results 物件中的其他 sub_match 物件對應於正規表示式中的子群組(由括號表示)。
例如,考慮以下正規表示式:
<code class="cpp">"ab(c)"</code>
它有一個捕獲組捕獲字元「c」。以下程式碼使用 std::regex_iterator 尋找多個符合項,防止字串被破壞:
<code class="cpp">std::string str("abcdefabcghiabc"); std::regex rgx1("abc"); smatch smtch; while (regex_search(str, smtch, rgx1)) { std::cout << smtch[0] << std::endl; str = smtch.suffix().str(); }</code>
此程式碼列印「abc」三次。
或者,std::sregex_iterator 可以是利用,提供更有效率和字串保留的方法:
<code class="cpp">std::string s = "abcdefabcghiabc"; for (std::sregex_iterator i = std::sregex_iterator(s.begin(), s.end(), r); i != std::sregex_iterator(); ++i) { std::smatch m = *i; std::cout << "Match value: " << m.str() << "\n"; std::cout << " Capture: " << m[1].str() << "\n"; }</code>
此程式碼列印完整的符合和擷取值,提供對std:: match_results::size() 行為的透徹理解。
以上是`std::match_results::size()` 如何決定正規表示式中的符合數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!