欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

asp.net高效替换大容量字符实现代码

程序员文章站 2022-05-22 14:18:56
一般进行替换操作都这样:复制代码 代码如下:str=str.replace(字符串一,字符串二) 不难发现一个问题,如果str要循环替换很多次,下一次替换时会累加上上次替换...
一般进行替换操作都这样:
复制代码 代码如下:

str=str.replace(字符串一,字符串二)

不难发现一个问题,如果str要循环替换很多次,下一次替换时会累加上上次替换的内容,并且全遍历一次,如果字符串二很多,替换的过程就像阶梯效果,越来越大,所以速度越来越慢。要解决这个问题只能找另外的方法替换这种表达方式。

如何以更高效率代替这种操作? 思路如下:
每次替换完后,在下次替换时先排除这次替换的内容,累加本次替换的内容。
复制代码 代码如下:

public regex returnmatch(string str)//匹配正则
{
regex r;
r = new regex(@str,regexoptions.ignorecase);
return r;
}
/// <summary>
/// 替换
/// </summary>
/// <param name="sdetail">要处理的字符</param>
/// <param name="regex">正则表达式</param>
/// <param name="replace_str">要替换的内容</param>
/// <returns>处理完的字符</returns>
public string replace(string sdetail,string regex)
{
int last_index=0;
string cut_str=sdetail;
string return_str="";
regex r;
match m;
r = returnmatch(regex);
for (m = r.match(sdetail); m.success; m = m.nextmatch())
{
int n=m.groups[0].length;//匹配长度
cut_str=cut_str.substring(last_index,cut_str.length-last_index);//去掉上次后的结果
int k=cut_str.indexof(m.groups[0].tostring());//当前位置
string this_v=cut_str.substring(k,n);//当前匹配的值
string str3=cut_str.substring(0,k+n);//当前得到的值
//return_str+=str3.replace(m.groups[0].tostring(),return_item_content(m.groups[0].tostring()));
return_str+=evn(str3,m);
last_index=k+n;//记录当前匹配的位置


}
if(return_str!="")
sdetail=return_str+cut_str.substring(last_index,cut_str.length-last_index);
return sdetail;
}
}