std::basic_regex<CharT,Traits>:: mark_count
From cppreference.net
<
cpp
|
regex
|
basic regex
|
unsigned
mark_count
(
)
const
;
|
(начиная с C++11) | |
Возвращает количество помеченных подвыражений (также известных как группы захвата) в регулярном выражении.
Содержание |
Параметры
(нет)
Возвращаемое значение
Количество помеченных подвыражений в регулярном выражении.
Исключения
Может генерировать исключения, определяемые реализацией.
Пример
Запустить этот код
#include <iostream> #include <regex> int main() { std::regex r1{"abcde"}; std::cout << "r1 has " << r1.mark_count() << " subexpressions" << '\n'; // Ожидается: 0 std::regex r2{"ab(c)de"}; std::cout << "r2 has " << r2.mark_count() << " subexpressions" << '\n'; // Ожидается: 1 std::regex r3{"a(bc)d(e)"}; std::cout << "r3 has " << r3.mark_count() << " subexpressions" << '\n'; // Ожидается: 2 // Вложенные подвыражения std::regex r4{"abc(de(fg))"}; std::cout << "r4 has " << r4.mark_count() << " subexpressions" << '\n'; // Ожидается: 2 // Экранированные скобки std::regex r5{"a(bc\\(\\)de)"}; std::cout << "r5 has " << r5.mark_count() << " subexpressions" << '\n'; // Ожидается: 1 // Использование флага nosubs std::regex r6{"ab(c)de", std::regex_constants::nosubs}; std::cout << "r6 has " << r6.mark_count() << " subexpressions" << '\n'; // Ожидается: 0 }
Вывод:
r1 has 0 subexpressions r2 has 1 subexpressions r3 has 2 subexpressions r4 has 2 subexpressions r5 has 1 subexpressions r6 has 0 subexpressions