C++字符串高效查找替换

  在最近的一个项目中,需要实现几万字符的查找替换,我使用CString的Replace花了两个小时,才完成替换。使用stl的string,花了大概6分钟。

  万般无赖,使用char*,自己实现查找替换吧,在1秒以内完成了替换。参考了网上的代码。

  直接上代码吧。

  
  
  
  
  1.  
  2. void CWebTransfer::Substitute(char *pInput, char *pOutput, char *pSrc, char *pDst)   
  3. {   
  4.     char *pi, *po, *p;   
  5.     int nSrcLen, nDstLen, nLen;   
  6.       
  7.     // 指向输入字符串的游动指针.   
  8.     pi = pInput;   
  9.     // 指向输出字符串的游动指针.   
  10.     po = pOutput;   
  11.     // 计算被替换串和替换串的长度.   
  12.     nSrcLen = strlen(pSrc);  
  13.     nDstLen = strlen(pDst);  
  14.       
  15.     // 查找pi指向字符串中第一次出现替换串的位置,并返回指针(找不到则返回null).   
  16.     p = strstr(pi, pSrc);   
  17.     if(p)   
  18.     {   
  19.         // 找到.   
  20.         while(p)   
  21.         {   
  22.             // 计算被替换串前边字符串的长度.   
  23.             nLen = (int)(p - pi);   
  24.             // 复制到输出字符串.   
  25.             memcpy(po, pi, nLen);   
  26.             memcpy(po + nLen, pDst, nDstLen);   
  27.             // 跳过被替换串.   
  28.             ppi = p + nSrcLen;   
  29.             // 调整指向输出串的指针位置.   
  30.             popo = po + nLen + nDstLen;   
  31.             // 继续查找.   
  32.             p = strstr(pi, pSrc);   
  33.         }   
  34.         // 复制剩余字符串.   
  35.         strcpy(po, pi);   
  36.     }   
  37.     else   
  38.     {   
  39.         // 没有找到则原样复制.   
  40.         strcpy(po, pi);   
  41.     }   
  42. }   

你可能感兴趣的:(C++,字符串,高效,休闲,查找替换)