2016-01-16 15:01
浏览 272


Can anyone provide some examples to explain the differences between regexp.Compile and regexp.CompilePOSIX? I read the documentation. But I can't get an intuitive understanding.

图片转代码服务由CSDN问答提供 功能建议

谁能提供一些示例来说明 regexp.Compile <代码> regexp.CompilePOSIX ? 我阅读了文档。 但是我无法获得直观的理解。

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • duangangmo0583 2016-01-16 15:20

    Perl- and POSIX-compatible regular expressions are similar in large parts, but differ in some key aspects, like for example submatching. This is mentioned here:

    POSIX defines that to resolve submatches, first chose the match that starts leftmost in the string. (This is traditional Perl behavior but here things diverge.) Among the submatches starting at the leftmost position in the string, choose the longest one overall.

    Say you have a regular expression (foo|foobar). When matching this expression against a string that would match several of the subexpressions (for example, foobarbaz would match both subpatterns, foo and foobar), a Perl-compatible regex would return the first match (foo), while a POSIX-compatible regex would return the longest match (foobar).

    Some example code (playground):

    package main
    import "fmt"
    import "regexp"
    func main() {
        pattern := "(foo|foobar)"
        str := []byte("foobarbaz")
        rPCRE, _ := regexp.Compile(pattern)
        rPOSIX, _ := regexp.CompilePOSIX(pattern)
        matchesPCRE := rPCRE.Find(str)
        // prints "foo"
        matchesPOSIX := rPOSIX.Find(str)
        // prints "foobar"
    解决 无用
    打赏 举报

相关推荐 更多相似问题