大佬教程收集整理的这篇文章主要介绍了php – preg_offset_capture子数组的保证顺序*保证*增加偏移量?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的用例非常简单:
preg_match_all("/$regEXP/",$content,$matches,PREG_OFFSET_CAPTURE);
我知道$regexp不包含任何子模式,所以文档告诉我,$matches [0]将是一个2元素数组的数组,其中每个子数组都有数字键0的元素,其中包含一个字符串,匹配模式,数字键1包含偏移量到匹配发生的$内容.而尽管数组元素通过增加偏移量来排序似乎是合理的,但我看不到需要哪里,因此如果不是这样,它将是一个错误.虽然我无法想象如何做到有用的效果,也许可能有一些方法来实现preg_match_all与多个线程附加他们的部分结果,而不合并到完全排序的顺序.
在我特定的情况下,我只关心偏移量,而不是匹配的字符串,但关键是偏移量增加.所以用腰带和吊带的心态我编码:
preg_match_all("/$regEXP/",PREG_OFFSET_CAPTURE); $offsets = array(); foreach ($matches as $match) { $offsets[] = $match[1]; } sort($offsets);
那么换另一种方式,是最终的排序($offsets)一个有保证的循环浪费?
如果不能让我遇到一个相关但可能单独的问题的深度麻烦,如果这种排序有潜力,那么如果显示出默认的SORT_REGULAR标志,或是明确指定SORT_NUMERIC,那么它/由于preg_match_all中产生的偏移量必须是数值?
完全匹配应始终以字符串上升顺序排列. PHP实现与设置start_offset的循环的全局匹配
在最近的完整匹配结束,直到主题字符串的结尾.那就是找到第一场比赛,然后是第二场比赛
第三,等等.
如果你想验证我是不是很可能会误读源代码(或者丢失一些重要的东西),你可以查看这个函数
ext / pcre / PHP_pcre.c中的PHP_pcre_match_impl. preg_match_all将全局参数设置为1.最终引起了我的注意
的while循环为全局:
/*Advance to the position right after the last full match*/ start_offset = offsets[1];
如果设置了全局,则循环将重新使用新的偏移量,并再次调用pcre_exec.
关于您的SORT_NUMERIC问题:
很难说设置SORT_NUMERIC使排序使用Numeric_compare_function进行元素比较,其中SORT_REGULAR使用COR_219_11845@pare_function.
compare_function做一个类型检查,然后决定从那里做比较,而numeric_compare_function只是盲目地转换成双打.比较两个都是比较的,只是比较它们而不做任何转换.所以它最终将取决于哪个更快:盲目转换为双倍,或执行类型检查.
以上是大佬教程为你收集整理的php – preg_offset_capture子数组的保证顺序*保证*增加偏移量?全部内容,希望文章能够帮你解决php – preg_offset_capture子数组的保证顺序*保证*增加偏移量?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。