in reply to New regex trick...
I understand (I think) why this is fast. What I don't understand is how it works. I'll admit that I am not much of regex hacker, but how does the variable length look behind now how far to look, in the case of quantifiers, especially greedy ones? It seems that the goal of the anchor is to prevent backtracking (hence the speed gains) but how does it now when to stop? If the \K anchor tells the regex engine to watch for the oncoming regex and stop matching there, whats the difference between \K and a minimal match, or negated character class? If the engine doesn't stop at the first instance of, say '.' (as in your example) how do you keep it from backtracking (which is where I'm presuming the speed gains come from)? Or is \K an optimization using sexegers?
Now, japhy I have absolute faith in your pattern - foo, so I take it on faith that this works. What I'm curious about is how. Am I missing something in thinking that the performance gains here are related to backtracking?
Cheers,Light a man a fire, he's warm for a day. Catch a man on fire, and he's warm for the rest of his life. - Terry Pratchet
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re: Re: New regex trick...
by japhy (Canon) on Jul 22, 2002 at 19:56 UTC | |
by erikharrison (Deacon) on Jul 22, 2002 at 20:34 UTC | |
by japhy (Canon) on Jul 22, 2002 at 20:49 UTC | |
by redsquirrel (Hermit) on Jul 22, 2002 at 21:08 UTC | |
by shelob101 (Sexton) on Jul 23, 2002 at 20:11 UTC |