首頁 >後端開發 >C++ >`std::match_results::size()` 如何決定正規表示式中的符合數?

`std::match_results::size()` 如何決定正規表示式中的符合數?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-04 12:43:02274瀏覽

How does `std::match_results::size()` determine the number of matches in a regular expression?

使用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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn