Карта сайта Kansoftware
НОВОСТИУСЛУГИРЕШЕНИЯКОНТАКТЫ
Разработка программного обеспечения

regex_match

Boost , Boost.Regex 5.1.2 , Reference

Boost C++ Libraries

...one of the most highly regarded and expertly designed C++ library projects in the world. Herb Sutter and Andrei Alexandrescu, C++ Coding Standards

PrevUpHomeNext
#include <boost/regex.hpp>

Алгоритм<regex_match>определяет, соответствует ли данное регулярное выражениевсейзаданной последовательности символов, обозначаемой парой двунаправленных итераторов, алгоритм определяется следующим образом, основное использование этой функции — валидация ввода данных.

[Important] Important

Обратите внимание, что результат верен только в том случае, если выражение соответствуетцеломувходной последовательности. Если вы хотите найти выражение где-то в последовательности, используйте<regex_search>. Если вы хотите сопоставить приставку строки символа, используйте<regex_search>с флагом match_continuous set.

template <class BidirectionalIterator, class Allocator, class charT, class traits>
bool regex_match(BidirectionalIterator first, BidirectionalIterator last,
                 match_results<BidirectionalIterator, Allocator>& m,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
template <class BidirectionalIterator, class charT, class traits>
bool regex_match(BidirectionalIterator first, BidirectionalIterator last,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
template <class charT, class Allocator, class traits>
bool regex_match(const charT* str, match_results<const charT*, Allocator>& m,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
template <class ST, class SA, class Allocator, class charT, class traits>
bool regex_match(const basic_string<charT, ST, SA>& s,
                 match_results<typename basic_string<charT, ST, SA>::const_iterator, Allocator>& m,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
template <class charT, class traits>
bool regex_match(const charT* str,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
template <class ST, class SA, class charT, class traits>
bool regex_match(const basic_string<charT, ST, SA>& s,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);
Description
template <class BidirectionalIterator, class Allocator, class charT, class traits>
bool regex_match(BidirectionalIterator first, BidirectionalIterator last,
                 match_results<BidirectionalIterator, Allocator>& m,
                 const basic_regex <charT, traits>& e,
                 match_flag_type flags = match_default);

Требуется: Двунаправленный итератор соответствует требованиям двухнаправленного итератора (24.1.4).

Эффекты: Определяет, существует ли точное соответствие между регулярным выражениемeи всей последовательностью символов [первый, последний], параметрфлагов(см.<match_flag_type>) используется для контроля того, как выражение совпадает с последовательностью символов. Возвращается истинно, если такой матч существует, ложно иначе.

Бросает:<std::runtime_error>если сложность сопоставления выражения со строкой символа N начинает превышать O(N2), или если программа исчерпала пространство стека при сопоставлении выражения (если Boost). Regex настраивается в рекурсивном режиме, или если спичечный аппарат исчерпал свое разрешенное выделение памяти (если Boost). Regex настроен в нерекурсивном режиме.

Пост-условия: Если функция возвращается ложной, то влияние на параметрмне определено, иначе эффекты на параметрмприведены в таблице:

Элемент

ценность

<m.size()>

<1+ e.mark_count()>

<m.empty()>

<false>

<m.prefix().first>

<first>

<m.prefix().last>

<first>

<m.prefix().matched>

<false>

<m.suffix().first>

<last>

<m.suffix().last>

<last>

<m.suffix().matched>

<false>

<m[0].first>

<first>

<m[0].second>

<last>

<m[0].matched>

истинно, если был найден полный матч, и ложно, если это был частичный матч (найден в результате матча_частичный флаг устанавливается).

<m[n].first>

Для всех целых чисел<n<m.size()>начало последовательности, которая соответствовала субэкспрессииn. Альтернативно, если в матче не участвовало подвыражениеn, то<last>

.

<m[n].second>

Для всех целых чисел<n<m.size()>конец последовательности, которая соответствовала субэкспрессииn. Альтернативно, если в матче не участвовало подвыражениеn, то<last>

.

<m[n].matched>

Для всех целых чисел<n<m.size()>истинно, если в матче участвовало подвыражениеn, ложное иначе.

template <class BidirectionalIterator, class charT, class traits>
bool regex_match(BidirectionalIterator first, BidirectionalIterator last,
               const basic_regex <charT, traits>& e,
               match_flag_type flags = match_default);

Эффекты: Вести себя «как будто», сооружая экземпляр<match_results<BidirectionalIterator>what>, а затем возвращая результат<regex_match(first,last,what,e, flags)>.

template <class charT, class Allocator, class traits>
bool regex_match(const charT* str, match_results<const charT*, Allocator>& m,
               const basic_regex <charT, traits>& e,
               match_flag_type flags = match_default);

Эффекты: Возвращает результат<regex_match(str,str +char_traits<charT>::length(str), m,e,flags)>.

template <class ST, class SA, class Allocator,
         class charT, class traits>
bool regex_match(const basic_string<charT, ST, SA>& s,
               match_results<typename basic_string<charT, ST, SA>::const_iterator, Allocator>& m,
               const basic_regex <charT, traits>& e,
               match_flag_type flags = match_default);

Эффекты: Возвращает результат<regex_match(s.begin(),s.end(),m,e,flags)>.

template <class charT, class traits>
bool regex_match(const charT* str,
               const basic_regex <charT, traits>& e,
               match_flag_type flags = match_default);

Эффекты: Возвращает результат<regex_match(str,str +char_traits<charT>::length(str), e,flags)>.

template <class ST, class SA, class charT, class traits>
bool regex_match(const basic_string<charT, ST, SA>& s,
               const basic_regex <charT, traits>& e,
               match_flag_type flags = match_default);

Эффекты: Возвращает результат<regex_match(s.begin(),s.end(),e,flags)>.

Examples

Следующий пример обрабатывает ответ ftp:

#include <stdlib.h>
#include <boost/regex.hpp>
#include <string>
#include <iostream>
using namespace boost;
regex expression("([0-9]+)(\\-| |$)(.*)");
// process_ftp: 
// on success returns the ftp response code, and fills 
// msg with the ftp response message. 
int process_ftp(const char* response, std::string* msg)
{
   cmatch what;
   if(regex_match(response, what, expression))
   {
      // what[0] contains the whole string 
      // what[1] contains the response code 
      // what[2] contains the separator character 
      // what[3] contains the text message. 
      if(msg)
         msg->assign(what[3].first, what[3].second);
      return std::atoi(what[1].first);
   }
   // failure did not match 
   if(msg)
      msg->erase();
   return -1;
}

PrevUpHomeNext

Статья regex_match раздела Boost.Regex 5.1.2 Reference может быть полезна для разработчиков на c++ и boost.




Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.



:: Главная :: Reference ::


реклама


©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007
Top.Mail.Ru

Время компиляции файла: 2024-08-30 11:47:00
2025-07-04 21:20:14/0.0074169635772705/0