Nene. Stack und Heap, hab ich lieb. Damit kenne ich mich schon aus.
Nur den Zusammenhang zwischen greedy und lazy im Zusammenhang mit dem PCRE-Stack hab ich nicht verstanden.
Hier ein glaube ich altes Beispiel.
banane
b(an)+ liefert 'banan'
b(an)+? liefert der Faulheit wegen nur noch 'ban'
Hänge ich dem Ausdruck ein e an
b(an)+?e
liefert das 'banane'. Er ackert also den Match mit (an)+? zwei Mal durch.
Genauso verhält es sich mit meinem Ausdruck ganz oben. Nur statt 'an' eben einzelne Zeilen mit einem Umbruch am Ende.
Wieso liefert greedy einen stack overflow und lazy keinen. Die X Zeilen muss er in beiden Fällen durchlaufen.
Meinste statt /n vielleicht nicht eher \n ?
Statt \n nehme ich \r\n, also einen Windows-Umbruch #13#10.