Condividi tramite


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 ());

Vedere anche

Altre risorse

Espressioni regolari di .NET Framework