标签:article back ack this var ati tmp net add
代码编译执行平台:VS2012+Win32+Debug
下面代码,作为平时代码库的储备,仅供各位猿友參考:
//替换指定的子串
//src:原字符串 target:待被替换的子串 subs:替换的子串
string replaceALL(const char* src, const string& target,const string& subs)
{
string tmp(src);
string::size_type pos =tmp.find(target),targetSize =target.size(),resSize =subs.size();
while(pos!=string::npos)//found
{
tmp.replace(pos,targetSize,subs);
pos =tmp.find(target, pos + resSize);
}
return tmp;
}
代码主要说明:
(1)tmp.find(target):查找子串第一次出现的下标;
(2)string::npos:表示未查找到子串时返回的数值。
MSDN中规定,其值定义例如以下:static const size_type npos = -1;,转换为无符号整型unsignned int表示的是string所能容纳的最大字符数。
(3)string::size_type (由字符串配置器 allocator 定义) 描写叙述的是 string的size,故需为无符号整数型别。
由于字符串配置器缺省以类型size_t 作为 size_type。
由于C++中istringstream无法提供按指定字符进行字符串的格式化输入,所以这里自己实现一个按指定字符进行字符串切割,然后再读取切割后的子串。
//qsort函数须要的比較函数。依照升序排序
int comp(const void*a,const void*b)
{
return *(int*)a-*(int*)b;
}
//按指定分隔符切割字符串
//src:源字符串 delimiter:分隔符集合
vector<string> split(const string& src,const string& delimiter)
{
vector<string> strRes;
int maxSubstrNum=src.size();
int* pos=new int[maxSubstrNum];
memset(pos,NULL,maxSubstrNum*sizeof(int));
int j=0;
for(int i=0;i<delimiter.size();++i)
{
string::size_type index=src.find(delimiter[i]);
while(index!=string::npos)
{
pos[j++]=index;
index=src.find(delimiter[i],index+1);
}
}
//排序
qsort(pos,j,sizeof(int),comp);
//取出第一个子串
string substrFir=src.substr(0,pos[0]);
if(substrFir!="")
strRes.push_back(substrFir);
//取出中间j-1个子串
for(int i=0;i<j-1;++i)
{
string substr=src.substr(pos[i]+1,pos[i+1]-pos[i]-1);
if(substr!="")
strRes.push_back(substr);
}
//取出最后一个子串
string substrLast=src.substr(pos[j-1]+1,src.size()-pos[j-1]-1);
if(substrLast!="")
strRes.push_back(substrLast);
delete[] pos;
return strRes;
}
代码主要说明:
(1)利用find()和substr()函数实现切割的功能;
(2)代码中。须要对切割符出现的下标进行排序。这样才干顺序的切割符下标取出子字符串。
[1]http://blog.sina.com.cn/s/blog_49370c500100ov3k.html
[2]http://www.jb51.net/article/55954.htm
标签:article back ack this var ati tmp net add
原文地址:http://www.cnblogs.com/jzdwajue/p/7112640.html