欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++11中regex正則表達(dá)式示例簡(jiǎn)述

 更新時(shí)間:2019年11月17日 10:43:30   作者:p__n  
這篇文章主要給大家介紹了關(guān)于c++11中regex正則表達(dá)式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用c++11具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

regex庫(kù)中涉及到的主要類型有:

  • 以std::string為代表的處理字符串的類型(我們知道還有存儲(chǔ)wchar_t的wstring類、原生c式字符串const char*等等,為了簡(jiǎn)化處理僅介紹std::string類型相關(guān)的操作,當(dāng)你把握住了regex的主脈絡(luò)之后,想使用其他的版本只要類比就可以)
  • std::regex類,該類型需要一個(gè)代表正則表達(dá)式的字符串和一個(gè)文法選項(xiàng)作為輸入,當(dāng)文法選項(xiàng)不提供時(shí)默認(rèn)為ECMAScript。
  • std::match_results類,該類用來記錄匹配的結(jié)果,這是一個(gè)模板類,該類的模板參數(shù)是一個(gè)迭代器類型,對(duì)于std::string來說我們定義了smatch作為match_results<string::const_iterator>作為別名。
  • std::sub_match類,該類其實(shí)封裝了兩個(gè)迭代器,第一個(gè)代表開始部分,第二個(gè)代表結(jié)束部分,就像你用兩個(gè)下表索引去表達(dá)一個(gè)字符串的某一個(gè)子串一樣。這個(gè)類就是通過這樣的方式提供原字符串的某一個(gè)子串作為結(jié)果。實(shí)際上match_results中就封裝了一些std::sub_match類型的對(duì)象。(為什么是一些而不是一個(gè),因?yàn)橐淮纹ヅ淇赡軙?huì)產(chǎn)生多個(gè)結(jié)果返回,regex認(rèn)為每個(gè)括號(hào)對(duì)構(gòu)成一個(gè)子匹配項(xiàng),regex匹配的結(jié)果可以顯式每個(gè)子匹配項(xiàng)匹配到的內(nèi)容。)
  • 現(xiàn)在我們有了表達(dá)字符串的類,表達(dá)正則匹配的類,表達(dá)匹配結(jié)果的類,接下來regex提供三個(gè)匹配函數(shù):
bool std::regex_match(...)
bool std::regex_search(...)
string std::regex_replace(...)//實(shí)際上返回類型是根據(jù)你輸入的數(shù)據(jù)類型對(duì)應(yīng)的basic_string類。

首先說明三個(gè)函數(shù)功能上的不同,std::regex_match是全文匹配,即它希望你輸入的字符串要和正則表達(dá)式全部匹配,才認(rèn)為匹配成功,否則匹配失敗,而std::regex_search是在你輸入的字符串中不斷搜索符合正則表達(dá)式描述的子字符串,然后將第一個(gè)匹配到的子字符串返回。std::regex_replace是在std::regex_search的基礎(chǔ)上更進(jìn)一步,可以將匹配的子字符串替換為你提供的字符串。

看幾個(gè)例子:

#include <iostream>
#include <string>
#include <regex>

int main() {
 std::regex pattern("\\d{4}");
 std::string content("hello_2018");
 std::smatch result;
 if (std::regex_match(content, result, pattern)) {
 std::cout << result[0];
 }
 system("pause");
 return 0;
}

匹配失敗,什么都不會(huì)輸出。

這里說明一下為什么輸出的是result[0],其實(shí)result[0]返回的就是一個(gè)sub_match類型的對(duì)象。regex中認(rèn)為正則表達(dá)式的每個(gè)括號(hào)對(duì)構(gòu)成一個(gè)子匹配項(xiàng),并認(rèn)為整個(gè)字符串作為0號(hào)子匹配項(xiàng),然后根據(jù)左括號(hào)出現(xiàn)的位置,從1號(hào)開始編號(hào),因此返回的result[0]就是匹配整個(gè)正則表達(dá)式的字符串。

#include <iostream>
#include <string>
#include <regex>

int main() {
 std::regex pattern("\\d{4}");
 std::string content("hello_2018 by_2017");
 std::smatch result;
 if (std::regex_search(content, result, pattern)) {
 std::cout << result[0];
 }
 system("pause");
 return 0;
}

搜索到第一個(gè)符合正則表達(dá)式的子串,輸出 2018。

#include <iostream>
#include <string>
#include <regex>

int main() {
 std::regex pattern("\\d{4}");
 std::string content("hello_2018 by_2017");
 std::smatch result;

 auto begin = content.cbegin();
 auto end = content.cend();
 while (std::regex_search(begin, end, result, pattern)) {
 std::cout << result[0] << " ";
 begin = result[0].second;
 }
 system("pause");
 return 0;
}

用上述方式可以輸出字符串中所有符合正則表達(dá)式匹配要求的字符串,輸出 2018 2017。

#include <iostream>
#include <string>
#include <regex>

int main() {
 std::regex pattern("\\d{4}");
 std::string content("hello_2018 by_2017");

 std::string result = std::regex_replace(content, pattern, "everyone");
 std::cout << result;
 system("pause");
 return 0;
}

輸出 hello_everyone by_everyone。

以上就是c++11提供的regex模塊的主要脈絡(luò),其余的關(guān)于對(duì)const char* 、wcahr_t類型的支持,以及regex_iterator、regex_token_iterator等迭代器的使用,以及掌控正則表達(dá)式行為方式的syntax_option_type的詳細(xì)內(nèi)容,等你需要去了解的時(shí)候去看官網(wǎng)的詳解,相信學(xué)起來并不難。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • c++讀寫文件流實(shí)例程序講解

    c++讀寫文件流實(shí)例程序講解

    這篇文章主要介紹了c++讀寫文件流實(shí)例,大家參考使用吧
    2013-12-12
  • C++虛繼承原理與類布局深度分析

    C++虛繼承原理與類布局深度分析

    這篇文章主要介紹了C++虛繼承原理與類布局分析,本文的目標(biāo)是探究虛繼承的實(shí)現(xiàn)方式和類布局(Class Layout)的具體規(guī)則,需要的朋友可以參考下
    2024-04-04
  • C語(yǔ)言實(shí)現(xiàn)雙人反彈球游戲

    C語(yǔ)言實(shí)現(xiàn)雙人反彈球游戲

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)雙人反彈球游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Qt數(shù)據(jù)庫(kù)相關(guān)應(yīng)用開發(fā)總結(jié)

    Qt數(shù)據(jù)庫(kù)相關(guān)應(yīng)用開發(fā)總結(jié)

    這篇文章主要為大家介紹了在Qt數(shù)據(jù)庫(kù)應(yīng)用開發(fā)中的一些經(jīng)驗(yàn)總結(jié),以及一些組件的使用介紹。文中的示例代碼講解詳細(xì),需要的可以參考一下
    2022-02-02
  • C++中int、DWORD和QWORD示例詳解

    C++中int、DWORD和QWORD示例詳解

    當(dāng)談?wù)揅++編程語(yǔ)言時(shí),以下術(shù)語(yǔ)經(jīng)常被提及:int、DWORD和QWORD,它們是用于表示不同數(shù)據(jù)類型和長(zhǎng)度的關(guān)鍵字,本文通過舉例給大家詳細(xì)介紹,感興趣的朋友一起看看吧
    2024-06-06
  • C語(yǔ)言中如何判斷質(zhì)數(shù)

    C語(yǔ)言中如何判斷質(zhì)數(shù)

    這篇文章主要介紹了C語(yǔ)言中的判斷質(zhì)數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • C語(yǔ)言超細(xì)致講解函數(shù)遞歸

    C語(yǔ)言超細(xì)致講解函數(shù)遞歸

    程序調(diào)???的編程技巧稱為遞歸?recursion)函數(shù)??調(diào)???就是遞歸,你也可以理解成是?種嵌套結(jié)構(gòu),但遞歸分為倆部分,第?是“遞”,進(jìn)?嵌套結(jié)構(gòu)。第?是”歸“,最終會(huì)?步?步返回。第?次接觸遞歸都會(huì)很懵,慢慢理解這個(gè)過程就明?了
    2022-05-05
  • C語(yǔ)言鄰接表建立圖詳解

    C語(yǔ)言鄰接表建立圖詳解

    這篇文章主要介紹了C語(yǔ)言鄰接表建立圖,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • c++重載的詳細(xì)總結(jié)

    c++重載的詳細(xì)總結(jié)

    作為成員函數(shù)重載符,對(duì)于雙目操作符重載函數(shù)只需一個(gè)形參,對(duì)于單目操作符重載函數(shù)不需要形參
    2013-09-09
  • Matlab利用隨機(jī)森林(RF)算法實(shí)現(xiàn)回歸預(yù)測(cè)詳解

    Matlab利用隨機(jī)森林(RF)算法實(shí)現(xiàn)回歸預(yù)測(cè)詳解

    這篇文章主要為大家詳細(xì)介紹了Matlab如何利用隨機(jī)森林(RF)算法實(shí)現(xiàn)回歸預(yù)測(cè),以及自變量重要性排序的操作,感興趣的小伙伴可以了解一下
    2023-02-02

最新評(píng)論