这篇文章主要介绍“C#回溯与非回溯怎么实现”,在日常操作中,相信很多人在C#回溯与非回溯怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#回溯与非回溯怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
使用“(?>…)”方式进行非回溯声明。由于正则表达式引擎的贪婪特性,导致它在某些情况下,将进行回溯以获得匹配
请看下面的C#正则表达式之回溯与非回溯示例:
string x = "Live for nothing,die for something"; Regex r1 = new Regex(@".*thing,"); if (r1.IsMatch(x)) { Console.WriteLine("match:" + r1.Match(x).Value);//输出:Live for nothing, } Regex r2 = new Regex(@"(?>.*)thing,"); if (r2.IsMatch(x))//不匹配 { Console.WriteLine("match:" + r2.Match(x).Value); } //在r1中,“.*”由于其贪婪特性,将一直匹配到字符串的***, //随后匹配“thing”,但在匹配“,”时失败, //此时引擎将回溯,并在“thing,”处匹配成功。 //在r2中,由于强制非回溯,所以整个表达式匹配失败。
到此,关于“C#回溯与非回溯怎么实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!