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)