.net - Regex.Replace 中的 "or"运算符是否有理论表达式大小限制

标签 .net regex limit

Regex.Replace 上的“或”运算符是否存在理论表达式大小限制
比如 Regex.Replace("abc","(a|c|d|e...continue say 500000 elements here)","zzz") ?

.NET 实现上的任何 stackoverflowException 吗?

谢谢

最佳答案

虽然每个正则表达式引擎都有自己的实现限制,但没有理论上的限制。在这种情况下,由于您使用的是 .NET,因此限制是由于 .NET 运行时可以使用的内存量。

具有一百万个 alerations 的正则表达式对我来说很好用:

string input = "a<142>c";
var options = Enumerable.Range(0, 1000000).Select(x => "<" + x + ">");
string pattern = string.Join("|", options);
string result = Regex.Replace(input, pattern, "zzz");

结果:
azzzc

虽然它很慢。将选项数量增加到 1000 万给我一个 OutOfMemoryException .

您可能会从另一种方法中受益。

关于.net - Regex.Replace 中的 "or"运算符是否有理论表达式大小限制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7528938/

相关文章:

c# - 如何在控件中使用 PreLoad 事件?

regex - 如何使用 Excel 公式来验证自定义的电子邮件地址?

MySql 查询 : Select top 3 rows from table for each category

android - Google MAPs API for android 限制 2500 个请求/天是每个客户端设备还是每个应用程序 key ?

mysql - mysql中concat和limit的语法错误

.net - 基于开源 .net Windows 窗体的控件,例如 : gantt chart, 日历和调度程序

.net - 无法将 System.Xml.XmlNode 转换为 System.Xml.Linq.XElement

javascript - 在按钮单击事件结束时调用 JavaScript 函数

JavaScript,RegExp - 替换为涉及标记表达式的评估表达式?

C++11 正则表达式,非贪婪