C++11 字符串分割代码示例如下,很显然, 使用了C++11 特性,代码简洁好多
#include <iostream> #include <string> #include <vector> #include <regex> using namespace std; //没有使用C++11特性 vector<string> testSplit(string srcStr, const string& delim) { int nPos = 0; vector<string> vec; nPos = srcStr.find(delim.c_str()); while(-1 != nPos) { string temp = srcStr.substr(0, nPos); vec.push_back(temp); srcStr = srcStr.substr(nPos+1); nPos = srcStr.find(delim.c_str()); } vec.push_back(srcStr); return vec; } //使用C++11特性 vector<string> testSplit11(const string& in, const string& delim) { vector<string> ret; try { regex re{delim}; return vector<string>{ sregex_token_iterator(in.begin(), in.end(), re, -1), sregex_token_iterator() }; } catch(const std::exception& e) { cout<<"error:"<<e.what()<<std::endl; } return ret; } int main() { vector<string>ret = testSplit("how many credits ?", " "); for(int i = 0 ; i < ret.size(); ++i) { cout<<ret[i]<<endl; } return 0; }
C++ 实现字符串分割函数 split
#include <iostream> #include <vector> using namespace std; vector<string> split( strData ) { vector<string> vecData; int nPos = strData.find( "," ); while( nPos > 0 ) { strTmp = strLine.substr( 0, nPos ); vecData.push_back( strTmp ); strLine.erase( 0, nPos+1 ); nPos = strData.find( "," ); } vecData.push_back( strData ); return vecData; }
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论(0)