Effizientes Verketten von Strings mit LINQ
Der traditionelle Ansatz zum Verketten von Strings umfasst die Verwendung eines StringBuilder und einer Schleife, wie im angegebenen Codeausschnitt gezeigt . Obwohl diese Methode effektiv ist, kann sie bei großen Datensätzen ausführlich und ineffizient sein. LINQ bietet eine präzisere und möglicherweise schnellere Lösung für diese Aufgabe.
Mit der Aggregate-Methode von LINQ können wir Zeichenfolgen wie folgt verketten:
string[] words = { "one", "two", "three" }; var res = words.Aggregate( "", // Start with an empty string for the empty list case (current, next) => current + ", " + next); Console.WriteLine(res);
Dieser Ausdruck erstellt eine neue Zeichenfolge, indem er jedes Element kombiniert des Wortarrays mit Komma und Leerzeichen. Aggregatabfragen werden sofort ausgeführt, im Gegensatz zur verzögerten Ausführung in den meisten anderen LINQ-Operationen.
Eine weitere Variante dieses Ansatzes beinhaltet die Verwendung eines StringBuilder innerhalb der Aggregate-Methode für Speichereffizienz:
var res = words.Aggregate( new StringBuilder(), (current, next) => current.Append(current.Length == 0? "" : ", ").Append(next)) .ToString();
Diese Variante bietet Ähnliche Leistung wie String.Join, eine weitere Option zum effizienten Verketten von Zeichenfolgen.
Das obige ist der detaillierte Inhalt vonWie kann LINQ die Effizienz der String-Verkettung verbessern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!