正则表达式——非捕获分组

  目前为止,总共介绍了括号的三种用途: 分组,将相关的语速归拢到一起,构成单个元素;多选结构,规定可能出现的多个子表达示;引用分组,将子表达式匹配的文本存储起来,供之后引用。

  这三种用途并不是彼此独立的,而是互相重叠的: 单纯的分组可以视为“只包含一个多选分支的多选结构”;整个多选结构也会被视为单个元素,可以由单个量词限定。最重要的是,无论是否需要引用分组,只要出现了括号,正则表达式在匹配是就会把括号内的子表达式存储起来,提供引用。如果并不需要引用,保存这些信息无疑会影响正则表达式的性能;如果表达式比较复杂,要处理的文本有很多,更可能严重影响性能。

  为解决这种问题,正则表达式提供了非捕获分组(non-capturing group),非捕获分组类似普通的捕获分组,只是在开括号后紧跟一个问号和冒号(?:...),这样的括号叫做非捕获分组,它只能限定量词的作用范围,不捕获任何文本。在引用分组时,分组的编号同样会按开括号出现的顺序从左到右递增,只是必须以捕获分组为准,非捕获分组会略过

posted @ 2018-11-27 14:28  gaara724  阅读(2289)  评论(1编辑  收藏  举报