写本文前,我也是想偷懒,在网上找代码,懒得写这些小函数,然后找到的效果是这样的代码:
void StrReplace(char* strSrc, char* strFind, char* strReplace)
{
while (*strSrc != '\0')
{
if (*strSrc == *strFind)
{
if (strncmp(strSrc, strFind, strlen(strFind)) == 0)
{
int i = strlen(strFind);
int j = strlen(strReplace);
char* q = strSrc+i;
char* p = q;//p、q均指向剩余字符串的首地址
char* repl = strReplace;
int lastLen = 0;
while (*q++ != '\0')
lastLen++;
char* temp = new char[lastLen+1];//临时开辟一段内存保存剩下的字符串,防止内存覆盖
for (int k = 0; k < lastLen; k++)
{
*(temp+k) = *(p+k);
}
*(temp+lastLen) = '\0';
while (*repl != '\0')
{
*strSrc++ = *repl++;
}
p = strSrc;
char* pTemp = temp;//回收动态开辟内存
while (*pTemp != '\0')
{
*p++ = *pTemp++;
}
delete temp;
*p = '\0';
}
else
strSrc++;
}
else
strSrc++;
}
}
暂不说这个代码对不对,就看着这么长的代码,我就不想用了。我相信是可以有非常精简的实现的。找了半天,没有现成的代码,只有作罢,自己动手丰衣足食。
然后我就实现了精简的版本,最精简版的字符串替换函数代码如下:
void replace_str(char * dest,const char * oldstr,const char * newstr)
{
char* pold = strstr(dest,oldstr);
strcpy(pold,newstr);
}
擦,才几行代码,秒杀!上网查代码,反而浪费了更多时间,分分钟就自己写得出来,就是因为想偷懒,实际上反而得不偿失。
代码的思路就是,查找子字符串,然后将子字符串复制替换为新字符串,就这么简单。