Backtracking
Quando le espressioni regolari presentano criteri di corrispondenza facoltativi o alternativi, il modulo di gestione delle espressioni regolari, a un certo punto della valutazione di una stringa di input, può diramarsi in una o più direzioni per individuare tutte le corrispondenze possibili. Se non rileva alcuna corrispondenza nella prima direzione in cui esegue la ricerca, è necessario che il modulo torni alla posizione della stringa di input da cui ha avuto origine la diramazione e tenti con una corrispondenza alternativa.
Si consideri, ad esempio, un'espressione regolare progettata per individuare una delle due ortografie inglesi del colore grigio: gray e grey. Il carattere di alternanza | viene utilizzato per creare l'espressione regolare gr(a|e)y
, che può corrispondere a entrambe le ortografie. Se applicato alla stringa di input greengraygrowngrey
, si presuma che il modulo tenterà di effettuare prima la corrispondenza a gray
. Viene trovata la corrispondenza con i primi due caratteri nella stringa di input, gr
, quindi si verifica un errore in corrispondenza della e
di green
. Viene eseguito il backtracking a r
, l'ultima corrispondenza esatta prima del carattere alternativo, e si tenta di trovare la corrispondenza con grey
. Dopo che si è verificato un errore in corrispondenza della seconda e
, il modulo continua la ricerca fino a trovare la corrispondenza con le due parole incorporate gray
e grey
.
Nell'esempio di codice che segue viene illustrato come creare questa espressione regolare e come applicarla alla stringa di input.
' Define strings: "gray" and "grey".
Dim r As New Regex("gr(a|e)y")
Dim m As MatchCollection = r.Matches("greengraygrowngrey")
Console.WriteLine("Number of groups found = " & m.Count.ToString())
// Define strings: "gray" and "grey".
Regex r = new Regex("gr(a|e)y");
MatchCollection m = r.Matches("greengraygrowngrey");
Console.WriteLine("Number of groups found = " + m.Count.ToString ());