- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我已经使用 PHP 编写代码一段时间了,我一直在读到您应该只在必须时使用 preg_match
和 preg_replace
,因为这会降低性能。为什么是这样?在一个文件中使用 20 个 preg_matches
而不是使用另一个 PHP 函数真的很糟糕吗?
最佳答案
正如 Mike Brant 在他的回答中所说:使用任何 preg_*
函数都没有错,如果您需要它们。
您想知道在单个文件中进行 20 次 preg_match
调用是否是个好主意,老实说:我会说这太多了。我经常说 “如果您的问题解决方案在任何给定时间依赖于 3 个以上的正则表达式,那么您就是问题的一部分”。不过,我偶尔也会犯下自己的口头禅。
如果您正在使用 20 个 preg_match
调用,您很可能只需仔细查看实际的正则表达式即可将这个数字减半。正则表达式,尤其是 Perl 正则表达式,非常强大,非常值得花时间去了解它们。 为什么它们往往变慢的原因仅仅是因为必须解析正则表达式,并在某个低级别“翻译”到相当数量的分支和循环。比方说,如果您想用大写字符替换所有小写的 a
,您当然可以使用正则表达式,但在 PHP 中它看起来像这样:
preg_replace('/a/','A',$string);
查看表达式,第一个参数:它是一个作为参数传递的字符串。该字符串将被解析(解析时,将检查分隔符,创建匹配字符串,然后迭代字符串,将每个字符与模式(在本例中为 a
)进行比较,并且 如果子串匹配,它被替换。
看起来有点麻烦,特别是考虑到最后一步(比较子串和替换匹配)是我们真正想要的。
$string = str_replace('a','A',$string);
仅此而已,无需在解析和验证正则表达式时执行额外的检查。
不要忘记 preg_match
也构造了一个匹配数组,并且构造一个数组也不是免费的。
简而言之:正则表达式较慢,因为表达式被解析、验证并最终翻译成一组简单的低级指令。
请注意,在某些情况下,人们使用 explode
和 implode
进行字符串操作。这也创建了一个数组,它再次不是免费的。考虑到此后不久您将爆破同一个阵列。也许另一种选择更可取(在某些情况下,preg_replace
可以 在这里更快)。
基本上:正则表达式需要额外的处理,简单的字符串函数不需要。但是当有疑问时,只有一种方法可以绝对确定:设置测试脚本...
关于php - preg_match() 和 preg_replace() 慢吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14342427/
我想知道我们是否可以替换 if(preg_match('/boo/', $anything) 和 preg_match('/poo/', $anything)) 用正则表达式.. $anything
假设字符串是: $a = "abc-def" if (preg_match("/[^a-z0-9]/i", $a, $m)){ $i = "i stopped scanning '$a' beca
好的,所以我希望用户能够输入 A-Z 中的每个字符和 0-9 中的每个数字,但我不希望他们输入“特殊字符”。 代码: if (preg_match("/^[a-zA-Z0-9]$/", $user_n
我想使用 preg_match 来查找括号之间的文本,例如:$varx = "(xx)"; 最终输出将是 $match = 'xx'; 另一个例子$varx = "bla bla (yy) bla b
嘿伙计们,我正在尝试删除最后一个 _1.jpg 如果它存在于我的表达中,但我遇到了一些麻烦 场景如下。 image_name_1.jpg(应该是image_name.jpg) image_name_1
我需要修复这个 preg_match("/^[[0-9]{0,4}$/i", $input),它还需要接受负值。谢谢 最佳答案 if (preg_match('/^-?[0-9]{1,4}$/', $
我正在尝试提出一个符合 25 的正则表达式在这个字符串中: Always - 25 (Lifetime - 之间的空间量和 25可以是可变的,但尾随 (Lifetime将永远在
我试图通过仅过滤掉符合以下条件的单词来匹配字符串中的关键字: 任何地方都有大写字母的单词,例如“iPhone”或“camelCase” 连续大写的词组,例如“Pittsburgh Steelers”或
我在 mysql 字段中有此数据: First text text text text text text text text text text text text text text tex
我有这个代码 preg_match("/\bHTTP(.)+ (\d{3})/", $string) 在最后一个模式中,我必须检查一个可以由任何数字组成但不应该创建像 404 或 401 这样的数字的
你好,我想匹配下一行中的“@”, create@create_time:"2012-05-30 21:14:35.0",update_time:"2012-05-31 22:05:46.0" preg
我使用“或”运算符“|”只匹配 $name 变量的单词 $name = "one five six two"; if (preg_match('/(one|two)/i', $name)) {retu
大家好 我有一个字符串 Open Directory Sites (1-20 of 10000) 我需要得到 10000 作为答案.. 我如何使用 preg_match ???注意:这是重要的,匹配的
我想使用 preg_match 为带括号的子模式返回每个匹配项的数组。 我有这个代码: $input = '[one][two][three]'; if ( preg_match('/
我有一个像这样值的变量: $sentence = "When it comes time to renew your auto insurance policy, be aware of how yo
我只想允许使用字母、数字、空格、无色线和连字符。 到目前为止,我认为这个 preg_match 可以完成这项工作: if(preg_match('/[^a-z0-9 _]+$/i', $name))
这个问题与this直接相关我大约 15 分钟前提出的问题。这不是要与那个帖子重复,而是希望这更多是一种学习经验。 在提出的问题中,我试图找出导致 preg_match no deliminator f
我有以下字符串 № покупки(OrderId) : 12345 Доп.Информация 1 : Имя Доп.Информация 2 : Уставная деятельность 我
我正在尝试为我们的防火墙创建报告功能。 防火墙规则以 json 格式存储。 这是字符串的示例。 [{"id":1,"enabled":true,"description":"TEMP","matche
在多个模式的情况下,可以在相同的数组索引下返回 preg_match 的结果。我的意思是我有以下 preg_match 什么正在检查不同子字符串( '&q' 、 '?q' 、 '&keywords'
我是一名优秀的程序员,十分优秀!