String vs. StringBuilder

215

Ich verstehe den Unterschied zwischen Stringund StringBuilder( StringBuilderveränderlich), aber gibt es einen großen Leistungsunterschied zwischen den beiden?

Das Programm, an dem ich arbeite, enthält viele Groß- und Kleinschreibung (500+). Ist die Verwendung StringBuildereiner besseren Wahl?

Kuvo
quelle

Antworten:

236

Ja, der Leistungsunterschied ist erheblich. Weitere Informationen finden Sie im KB-Artikel " Verbessern der Verkettungsleistung von Zeichenfolgen in Visual C # ".

Ich habe immer versucht, zuerst aus Gründen der Klarheit zu codieren und später die Leistung zu optimieren. Das ist viel einfacher als umgekehrt! Nachdem ich jedoch den enormen Leistungsunterschied in meinen Anwendungen zwischen den beiden gesehen habe, denke ich jetzt etwas genauer darüber nach.

Glücklicherweise ist es relativ einfach, eine Leistungsanalyse für Ihren Code durchzuführen, um festzustellen, wo Sie die Zeit verbringen, und ihn dann so zu ändern, dass er StringBuilderbei Bedarf verwendet werden kann.

Jay Bazuzi
quelle
44
Eine gute Faustregel ist, Strings zu verwenden, wenn Sie es nicht ändern möchten, und StringBuilder zu verwenden, wenn Sie es ändern möchten.
Tim
31
Diese Antwort gefällt mir sehr gut, insbesondere der Rat, vor der Aufführung aus Gründen der Klarheit zu codieren. Als Entwickler verbringen wir mindestens genauso viel Zeit mit dem Lesen von Code wie mit dem Schreiben.
Scott Lawrence
Outlaw: Ich denke, das sollte eine eigene Antwort werden, über die separat abgestimmt wird, wenn ich StackOverflow richtig verstehe.
Jay Bazuzi
2
Aufgrund meiner Erfahrung können Sie mit einer Saite arbeiten, wenn Sie versuchen, etwa 10-15 Saiten zu konkatieren, aber wenn nein. von Strings sind mehr als das, dann benutze String Builder
Peeyush
3
Es hängt immer noch davon ab, wie man es benutzt, als Referenz für Tests, die ich mag Coding Horror - Die traurige Tragödie des Mikrooptimierungstheaters
Erik Philips
56

Um zu verdeutlichen, was Gillian über 4 Saiten gesagt hat, wenn Sie so etwas haben:

string a,b,c,d;
 a = b + c + d;

dann wäre es schneller mit Strings und dem Plus-Operator. Dies liegt daran, dass (wie Java, wie Eric betont) intern StringBuilder automatisch verwendet wird (tatsächlich wird ein Grundelement verwendet, das auch StringBuilder verwendet).

Wenn das, was Sie tun, jedoch näher liegt an:

string a,b,c,d;
 a = a + b;
 a = a + c;
 a = a + d;

Dann müssen Sie explizit einen StringBuilder verwenden. .Net erstellt hier nicht automatisch einen StringBuilder, da dies sinnlos wäre. Am Ende jeder Zeile muss "a" eine (unveränderliche) Zeichenfolge sein, sodass in jeder Zeile ein StringBuilder erstellt und entsorgt werden muss. Aus Gründen der Geschwindigkeit müssen Sie denselben StringBuilder verwenden, bis Sie mit dem Erstellen fertig sind:

string a,b,c,d;
StringBuilder e = new StringBuilder();
 e.Append(b);
 e.Append(c);
 e.Append(d);
 a = e.ToString();
James Curran
quelle
5
Es gibt keinen Grund, warum der C # -Compiler das zweite Sample anders als das erste behandeln muss. Insbesondere besteht keine Verpflichtung, am Ende jeder Zeile eine Zeichenfolge zu erstellen. Der Compiler verhält sich möglicherweise so, wie Sie es sagen, ist jedoch nicht dazu verpflichtet.
CodesInChaos
@CodesInChaos, eine unveränderliche Zeichenfolgenvariable wird am Ende jeder Zeile speziell zugewiesen. Schafft dies nicht die Verpflichtung, eine Zeichenfolge zu erstellen? Ich stimme jedoch dem Punkt zu, dass es keinen Grund gibt, jede einzelne Zeile anders zu behandeln (und ich bin mir nicht sicher, ob dies der Fall ist). Der Leistungsverlust ergibt sich jedoch aus der Neuzuweisung, sodass dies keine Rolle spielt.
Saeb Amini
@SaebAmini - Wenn aes sich um eine lokale Variable handelt und das Objekt, auf das verwiesen wird, keiner anderen Variablen zugewiesen wurde (auf die möglicherweise ein anderer Thread zugreifen kann), kann ein guter Optimierer feststellen, dass während dieser Sequenz von keinem anderen Codea zugegriffen wird Linien; nur der endgültige Wert der aDinge. So könnten diese drei Codezeilen so behandelt werden, als wären sie geschrieben a = b + c + d;.
ToolmakerSteve
29

Stringbuilder ist bevorzugt IF Sie mehrere Schleifen tun, oder Gabeln in Ihrem Code Pass ... aber für PURE Leistung, wenn Sie mit einem wegkommen kann SINGLE String Erklärung, dann die viel mehr performant ist.

Beispielsweise:

string myString = "Some stuff" + var1 + " more stuff"
                  + var2 + " other stuff" .... etc... etc...;

ist performanter als

StringBuilder sb = new StringBuilder();
sb.Append("Some Stuff");
sb.Append(var1);
sb.Append(" more stuff");
sb.Append(var2);
sb.Append("other stuff");
// etc.. etc.. etc..

In diesem Fall kann StringBuild als wartbarer angesehen werden, ist jedoch nicht leistungsfähiger als die Deklaration einzelner Zeichenfolgen.

9 mal von 10 ... benutze den String Builder.

Nebenbei bemerkt: string + var ist auch leistungsfähiger als der string.Format-Ansatz (im Allgemeinen), der intern einen StringBuilder verwendet (im Zweifelsfall ... Reflektor prüfen!)

Calebjenkins
quelle
17
Ich wünschte, Sie hätten gesagt, woher Sie das wissen / wie Sie das überprüfen können.
ChrisW
2
Sie überprüfen die Leistung im Reflektor nicht: Sie überprüfen die Leistung anhand des Timing-Release-Codes, analysieren mit einem Profiler und suchen mit dem Reflektor nach Erklärungen.
Albin Sunnanbo
3
Erwägen Sie die Verwendung von String.Format (), um eine kleine Anzahl kleiner Zeichenfolgen zu verketten. Dies ist insbesondere das Ziel, Nachrichten so zu formatieren, dass sie dem Benutzer angezeigt werden.
Gary Kindel
1
Das sind sehr schlechte Informationen. ("string myString ist performanter") überhaupt nicht wahr.
Tom Stickel
3
Die Informationen in dieser Antwort sind falsch. StringBuilder ist etwas schneller als die Verkettung in derselben Anweisung. Sie werden jedoch nur dann einen Unterschied zwischen den beiden feststellen, wenn Sie dies hunderttausend Mal tun ( Quelle ). Wie in der Quelle gesagt, "spielt es einfach keine Rolle!"
David Sherret
25

Ein einfaches Beispiel, um den Geschwindigkeitsunterschied bei der Verwendung von StringVerkettung zu demonstrieren StringBuilder:

System.Diagnostics.Stopwatch time = new Stopwatch();
string test = string.Empty;
time.Start();
for (int i = 0; i < 100000; i++)
{
    test += i;
}
time.Stop();
System.Console.WriteLine("Using String concatenation: " + time.ElapsedMilliseconds + " milliseconds");

Ergebnis:

Verwenden der Zeichenfolgenverkettung: 15423 Millisekunden

StringBuilder test1 = new StringBuilder();
time.Reset();
time.Start();
for (int i = 0; i < 100000; i++)
{
    test1.Append(i);
}
time.Stop();
System.Console.WriteLine("Using StringBuilder: " + time.ElapsedMilliseconds + " milliseconds");

Ergebnis:

Verwenden von StringBuilder: 10 Millisekunden

Infolgedessen dauerte die erste Iteration 15423 ms, während die zweite Iteration mit StringBuilder10 ms dauerte.

Es scheint mir, dass die Verwendung StringBuilderschneller ist, viel schneller.

Diizzy
quelle
24

Dieser Benchmark zeigt, dass die regelmäßige Verkettung schneller ist, wenn 3 oder weniger Zeichenfolgen kombiniert werden.

http://www.chinhdo.com/20070224/stringbuilder-is-not-always-faster/

StringBuilder kann die Speichernutzung erheblich verbessern, insbesondere wenn Sie 500 Zeichenfolgen addieren.

Betrachten Sie das folgende Beispiel:

string buffer = "The numbers are: ";
for( int i = 0; i < 5; i++)
{
    buffer += i.ToString();
}
return buffer;

Was passiert im Gedächtnis? Die folgenden Zeichenfolgen werden erstellt:

1 - "The numbers are: "
2 - "0"
3 - "The numbers are: 0"
4 - "1"
5 - "The numbers are: 01"
6 - "2"
7 - "The numbers are: 012"
8 - "3"
9 - "The numbers are: 0123"
10 - "4"
11 - "The numbers are: 01234"
12 - "5"
13 - "The numbers are: 012345"

Durch Hinzufügen dieser fünf Zahlen am Ende der Zeichenfolge haben wir 13 Zeichenfolgenobjekte erstellt! Und 12 von ihnen waren nutzlos! Beeindruckend!

StringBuilder behebt dieses Problem. Es ist keine "veränderbare Zeichenfolge", wie wir oft hören ( alle Zeichenfolgen in .NET sind unveränderlich ). Es funktioniert, indem ein interner Puffer, ein Array von Zeichen, beibehalten wird. Durch Aufrufen von Append () oder AppendLine () wird die Zeichenfolge dem leeren Bereich am Ende des char-Arrays hinzugefügt. Wenn das Array zu klein ist, wird ein neues, größeres Array erstellt und der Puffer dort kopiert. Im obigen Beispiel benötigt StringBuilder möglicherweise nur ein einziges Array, um alle 5 Ergänzungen zum String zu enthalten - abhängig von der Größe seines Puffers. Sie können StringBuilder mitteilen, wie groß der Puffer im Konstruktor sein soll.

Matt Trunnell
quelle
2
Minor nit: Es ist etwas seltsam zu sagen, dass "wir 13 String-Objekte erstellt haben und 12 davon nutzlos waren", und dann zu sagen, dass StringBuilder dieses Problem behebt. Immerhin haben Sie für sechs der Zeichenfolgen keine andere Wahl, als sie zu erstellen. sie kommen aus i.ToString(). Mit StringBuilder müssen Sie also noch 6 + 1 Zeichenfolgen erstellen. Das Erstellen von 13 Zeichenfolgen wurde auf 7 Zeichenfolgen reduziert. Aber das ist immer noch die falsche Sichtweise; Die Erstellung der sechs Zahlenfolgen ist nicht relevant. Fazit: Sie hätten die sechs Zeichenfolgen von einfach nicht erwähnen sollen i.ToString(). Sie sind nicht Teil des Effizienzvergleichs.
ToolmakerSteve
12

Ja, StringBuilderbietet eine bessere Leistung bei wiederholter Operation über eine Zeichenfolge. Dies liegt daran, dass alle Änderungen an einer einzelnen Instanz vorgenommen werden, sodass viel Zeit gespart werden kann, anstatt eine neue Instanz wie zu erstellen String.

String gegen Stringbuilder

  • String

    1. unter SystemNamespace
    2. unveränderliche (schreibgeschützte) Instanz
    3. Die Leistung nimmt ab, wenn eine kontinuierliche Wertänderung auftritt
    4. fadensicher
  • StringBuilder (veränderbare Zeichenfolge)

    1. unter System.TextNamespace
    2. veränderbare Instanz
    3. zeigt eine bessere Leistung, da neue Änderungen an der vorhandenen Instanz vorgenommen werden

Ich kann den Dotnet-Mob-Artikel nur empfehlen: String Vs StringBuilder in C # .

Verwandte Frage zum Stapelüberlauf : Veränderbarkeit der Zeichenfolge, wenn sich die Zeichenfolge in C # nicht ändert? .

Shamseer K.
quelle
12

String Vs String Builder:

Als erstes muss man wissen, in welcher Versammlung diese beiden Klassen leben?

So,

Zeichenfolge ist im SystemNamespace vorhanden.

und

StringBuilder ist im System.TextNamespace vorhanden.

Für die Zeichenfolgendeklaration :

Sie müssen den SystemNamespace einschließen . etwas wie das. Using System;

und

Für die StringBuilder- Deklaration:

Sie müssen den System.textNamespace einschließen . etwas wie das. Using System.text;

Nun kommt die eigentliche Frage.

Was ist der Unterschied zwischen string & StringBuilder ?

Der Hauptunterschied zwischen diesen beiden ist:

Zeichenfolge ist unveränderlich.

und

StringBuilder ist veränderbar.

Lassen Sie uns nun den Unterschied zwischen unveränderlich und veränderlich diskutieren

Veränderliche: : Mittel veränderbare.

Unveränderliche: : Mittel nicht veränderbarer.

Beispielsweise:

using System;

namespace StringVsStrigBuilder
{
    class Program
    {
        static void Main(string[] args)
        {
            // String Example

            string name = "Rehan";
            name = name + "Shah";
            name = name + "RS";
            name = name + "---";
            name = name + "I love to write programs.";

            // Now when I run this program this output will be look like this.
            // output : "Rehan Shah RS --- I love to write programs."
        }
    }
}

In diesem Fall werden wir also dasselbe Objekt fünfmal ändern.

Die offensichtliche Frage ist also: Was passiert eigentlich unter der Haube, wenn wir die gleiche Saite fünfmal wechseln?

Dies passiert, wenn wir dieselbe Zeichenfolge fünfmal ändern.

Schauen wir uns die Figur an.

Geben Sie hier die Bildbeschreibung ein

Erklärung:

Wenn wir diese Variable "name" zum ersten Mal auf "Rehan" initialisieren, dh string name = "Rehan" diese Variable wird auf dem Stapel "name" erstellt und zeigt auf diesen "Rehan" -Wert. Nachdem diese Zeile ausgeführt wurde: "name = name +" Shah ". Die Referenzvariable zeigt nicht mehr auf das Objekt" Rehan ", sondern auf" Shah "und so weiter.

So stringist unveränderlich Bedeutung , dass , wenn wir das Objekt im Speicher erstellen können wir nicht ändern.

Wenn wir also die nameVariable zusammenfassen, bleibt das vorherige Objekt im Speicher und es wird ein weiteres neues Zeichenfolgenobjekt erstellt ...

Aus der obigen Abbildung haben wir also fünf Objekte, die vier Objekte werden weggeworfen, sie werden überhaupt nicht verwendet. Sie bleiben immer noch im Gedächtnis und nehmen die Menge des Gedächtnisses ein. "Garbage Collector" ist dafür verantwortlich, dass die Ressourcen aus dem Speicher entfernt werden.

Im Falle einer Zeichenfolge haben wir also immer dann, wenn wir die Zeichenfolge immer wieder manipulieren, einige viele Objekte erstellt und bleiben dort im Speicher.

Das ist also die Geschichte von String Variable.

Schauen wir uns nun das StringBuilder-Objekt an. Beispielsweise:

using System;
using System.Text;

namespace StringVsStrigBuilder
{
    class Program
    {
        static void Main(string[] args)
        {
            // StringBuilder Example

            StringBuilder name = new StringBuilder();
            name.Append("Rehan");
            name.Append("Shah");
            name.Append("RS");
            name.Append("---");
            name.Append("I love to write programs.");


            // Now when I run this program this output will be look like this.
            // output : "Rehan Shah Rs --- I love to write programs."
        }
    }
}

In diesem Fall werden wir also dasselbe Objekt fünfmal ändern.

Die offensichtliche Frage ist also: Was passiert eigentlich unter der Haube, wenn wir den gleichen StringBuilder 5-mal ändern?

Dies passiert, wenn wir denselben StringBuilder fünfmal ändern.

Schauen wir uns die Figur an. Geben Sie hier die Bildbeschreibung ein

Erklärung: Im Fall eines StringBuilder-Objekts. Sie würden das neue Objekt nicht bekommen. Das gleiche Objekt wird im Speicher geändert. Selbst wenn Sie das Objekt ändern und beispielsweise 10.000 Mal, haben wir immer noch nur ein stringBuilder-Objekt.

Sie haben nicht viele Garbage-Objekte oder nicht referenzierte stringBuilder-Objekte, weil sie geändert werden können. Es ist veränderlich, was bedeutet, dass es sich im Laufe der Zeit ändert?

Unterschiede:

  • String ist im System-Namespace vorhanden, während Stringbuilder im System.Text-Namespace vorhanden ist.
  • string ist unveränderlich, wenn StringBuilder mutabe ist.
Rehan Shah
quelle
8

StringBuilder reduziert die Anzahl der Zuweisungen und Zuweisungen auf Kosten des zusätzlichen verwendeten Speichers. Bei ordnungsgemäßer Verwendung kann der Compiler die Notwendigkeit beseitigen, immer größere Zeichenfolgen immer wieder zuzuweisen, bis das Ergebnis gefunden wird.

string result = "";
for(int i = 0; i != N; ++i)
{
   result = result + i.ToString();   // allocates a new string, then assigns it to result, which gets repeated N times
}

vs.

String result;
StringBuilder sb = new StringBuilder(10000);   // create a buffer of 10k
for(int i = 0; i != N; ++i)
{
   sb.Append(i.ToString());          // fill the buffer, resizing if it overflows the buffer
}

result = sb.ToString();   // assigns once
Moswald
quelle
5

Die Leistung einer Verkettungsoperation für einen String oder ein StringBuilder-Objekt hängt davon ab, wie oft eine Speicherzuweisung erfolgt. Eine String-Verkettungsoperation weist immer Speicher zu, während eine StringBuilder-Verkettungsoperation nur Speicher zuweist, wenn der StringBuilder-Objektpuffer zu klein ist, um die neuen Daten aufzunehmen. Folglich ist die String-Klasse für eine Verkettungsoperation vorzuziehen, wenn eine feste Anzahl von String-Objekten verkettet ist. In diesem Fall können die einzelnen Verkettungsoperationen vom Compiler sogar zu einer einzigen Operation kombiniert werden. Ein StringBuilder-Objekt ist für eine Verkettungsoperation vorzuziehen, wenn eine beliebige Anzahl von Zeichenfolgen verkettet ist. Zum Beispiel, wenn eine Schleife eine zufällige Anzahl von Zeichenfolgen von Benutzereingaben verkettet.

Quelle: MSDN

user487069
quelle
3

StringBuilder ist besser zum Aufbau eines Strings aus vielen nicht konstanten Werten.

Wenn Sie eine Zeichenfolge aus vielen konstanten Werten erstellen, z. B. mehreren Wertzeilen in einem HTML- oder XML-Dokument oder anderen Textblöcken, können Sie einfach nur an dieselbe Zeichenfolge anhängen, da dies fast alle Compiler tun "Konstante Faltung", ein Prozess zum Reduzieren des Analysebaums, wenn Sie ständig manipuliert werden (wird auch verwendet, wenn Sie so etwas schreiben int minutesPerYear = 24 * 365 * 60). In einfachen Fällen, in denen nicht konstante Werte aneinander angehängt sind, reduziert der .NET-Compiler Ihren Code auf etwas Ähnliches wie das, was er StringBuildertut.

Wenn Ihr Anhang vom Compiler jedoch nicht auf etwas Einfacheres reduziert werden kann, benötigen Sie eine StringBuilder. Wie Fizch hervorhebt, ist es wahrscheinlicher, dass dies innerhalb einer Schleife geschieht.

JasonTrue
quelle
2

Ich glaube, StringBuilder ist schneller, wenn Sie mehr als 4 Zeichenfolgen haben, die Sie zusammenfügen müssen. Außerdem kann es einige coole Dinge wie AppendLine tun.

Gilligan
quelle
2

In .NET ist StringBuilder immer noch schneller als das Anhängen von Zeichenfolgen. Ich bin mir ziemlich sicher, dass sie in Java nur einen StringBuffer unter der Haube erstellen, wenn Sie Strings anhängen, sodass es keinen wirklichen Unterschied gibt. Ich bin mir nicht sicher, warum sie dies in .NET noch nicht getan haben.

Eric Z Bart
quelle
2

Die Verwendung von Zeichenfolgen zur Verkettung kann zu einer Laufzeitkomplexität in der Größenordnung von führen O(n^2).

Wenn Sie a verwenden StringBuilder, muss viel weniger Speicher kopiert werden. Mit dem können StringBuilder(int capacity)Sie die Leistung steigern, wenn Sie abschätzen können, wie groß das Finale sein Stringwird. Selbst wenn Sie nicht präzise sind, müssen Sie die Kapazität wahrscheinlich nur StringBuilderein paar Mal erhöhen, was ebenfalls zur Leistungssteigerung beitragen kann.

Steve g
quelle
2

Ich habe erhebliche Leistungssteigerungen durch die Verwendung des EnsureCapacity(int capacity)Methodenaufrufs für eine Instanz von StringBuilderfestgestellt, bevor er für einen Zeichenfolgenspeicher verwendet wurde. Normalerweise rufe ich das nach der Instanziierung in der Codezeile auf. Es hat den gleichen Effekt, als ob Sie Folgendes instanziieren StringBuilder:

var sb = new StringBuilder(int capacity);

Dieser Aufruf weist den benötigten Speicher im Voraus zu, wodurch bei mehreren Append()Vorgängen weniger Speicher zugewiesen wird . Sie müssen eine fundierte Vermutung anstellen, wie viel Speicher Sie benötigen, aber für die meisten Anwendungen sollte dies nicht zu schwierig sein. Normalerweise irre ich mich auf der Seite von etwas zu viel Gedächtnis (wir reden über 1k oder so).

Jason Jackson
quelle
Es ist nicht erforderlich, EnsureCapacityunmittelbar nach der StringBuilderInstanziierung aufzurufen . Instanziieren Sie einfach Folgendes StringBuilder: var sb = new StringBuilder(int capacity).
David Ferenczy Rogožan
Mir wurde gesagt, dass es hilft, eine Primzahl zu verwenden.
Karl Gjertsen
1

Nach den vorherigen Antworten ist das erste, was ich bei solchen Problemen immer mache, eine kleine Testanwendung zu erstellen. Führen Sie in dieser App einen Timing-Test für beide Szenarien durch und überzeugen Sie sich selbst, welcher schneller ist.

IMHO sollte das Anhängen von mehr als 500 Zeichenfolgeneinträgen auf jeden Fall StringBuilder verwenden.

RichS
quelle
1

String und StringBuilder sind eigentlich beide unveränderlich. Der StringBuilder verfügt über integrierte Puffer, mit denen seine Größe effizienter verwaltet werden kann. Wenn der StringBuilder die Größe ändern muss, wird er auf dem Heap neu zugewiesen. Standardmäßig ist die Größe auf 16 Zeichen festgelegt. Sie können dies im Konstruktor festlegen.

z.B.

StringBuilder sb = neuer StringBuilder (50);

capgpilk
quelle
2
Ich bin mir nicht sicher, ob Sie verstehen, was unveränderlich bedeutet. Saiten sind unveränderlich, sie können nicht geändert werden. Alles, was "geändert" wird, ist eigentlich nur, dass der alte Wert auf dem Heap bleibt, ohne dass ein Zeiger vorhanden ist, um ihn zu lokalisieren. StringBuilder (veränderlich) ist der Referenztyp auf dem Heap, der Zeiger auf den Heap wird geändert und der Speicherplatz für diese Änderung zugewiesen.
Tom Stickel
1

Die Verkettung von Zeichenfolgen kostet Sie mehr. In Java können Sie je nach Bedarf entweder StringBuffer oder StringBuilder verwenden. Wenn Sie eine synchronisierte und threadsichere Implementierung wünschen, wählen Sie StringBuffer. Dies ist schneller als die String-Verkettung.

Wenn Sie keine synchronisierte oder Thread-sichere Implementierung benötigen, wählen Sie StringBuilder. Dies ist schneller als die String-Verkettung und auch schneller als StringBuffer, da kein Synchronisationsaufwand entsteht.

Raffimd
quelle
0

StringBuilder ist wahrscheinlich vorzuziehen. Der Grund dafür ist, dass mehr Speicherplatz als derzeit benötigt zugewiesen wird (Sie legen die Anzahl der Zeichen fest), um Platz für zukünftige Anhänge zu lassen. Dann erfordern diese zukünftigen Anhänge, die in den aktuellen Puffer passen, keine Speicherzuweisung oder Speicherbereinigung, was teuer sein kann. Im Allgemeinen verwende ich StringBuilder für die Konzentration komplexer Zeichenfolgen oder für die Mehrfachformatierung. Wenn die Daten vollständig sind, konvertiere ich sie in einen normalen String und möchte wieder ein unveränderliches Objekt.

Deemer
quelle
0

Wenn Sie viel String-Verkettung durchführen, verwenden Sie einen StringBuilder. Wenn Sie mit einem String verketten, erstellen Sie jedes Mal einen neuen String, der mehr Speicherplatz beansprucht.

Alex

Alex Fort
quelle
0

Als allgemeine Faustregel gilt: Wenn ich den Wert der Zeichenfolge mehrmals festlegen muss oder wenn Anhänge an die Zeichenfolge angehängt sind, muss es sich um einen Zeichenfolgengenerator handeln. Ich habe Anwendungen gesehen, die ich in der Vergangenheit geschrieben habe, bevor ich etwas über String-Builder gelernt habe, die einen riesigen Speicherbedarf hatten, der immer weiter zu wachsen scheint. Durch Ändern dieser Programme zur Verwendung des String Builders wurde die Speichernutzung erheblich reduziert. Jetzt schwöre ich beim String Builder.

user13288
quelle
0

Mein Ansatz war immer, StringBuilder zu verwenden, wenn 4 oder mehr Zeichenfolgen verkettet werden ODER wenn ich nicht weiß, wie Verkettungen stattfinden sollen.

Guter leistungsbezogener Artikel dazu hier

Peter Mortensen
quelle
0

StringBuilder ist wesentlich effizienter, aber Sie werden diese Leistung nur sehen, wenn Sie eine große Menge an Zeichenfolgenänderungen vornehmen.

Im Folgenden finden Sie einen kurzen Codeabschnitt, der ein Beispiel für die Leistung enthält. Wie Sie sehen, sehen Sie erst dann eine deutliche Leistungssteigerung, wenn Sie in große Iterationen geraten.

Wie Sie sehen können, dauerten die 200.000 Iterationen 22 Sekunden, während die 1 Million Iterationen mit dem StringBuilderfast augenblicklich waren.

string s = string.Empty;
StringBuilder sb = new StringBuilder();

Console.WriteLine("Beginning String + at " + DateTime.Now.ToString());

for (int i = 0; i <= 50000; i++)
{
    s = s + 'A';
}

Console.WriteLine("Finished String + at " + DateTime.Now.ToString());
Console.WriteLine();

Console.WriteLine("Beginning String + at " + DateTime.Now.ToString());

for (int i = 0; i <= 200000; i++)
{
    s = s + 'A';
}

Console.WriteLine("Finished String + at " + DateTime.Now.ToString());
Console.WriteLine();
Console.WriteLine("Beginning Sb append at " + DateTime.Now.ToString());

for (int i = 0; i <= 1000000; i++)
{
    sb.Append("A");
}
Console.WriteLine("Finished Sb append at " + DateTime.Now.ToString());

Console.ReadLine();

Ergebnis des obigen Codes:

Beginn String + am 28/01/2013 16:55:40.

Fertige Saite + am 28/01/2013 16:55:40.

Beginn String + am 28/01/2013 16:55:40.

Fertige Saite + am 28/01/2013 16:56:02.

Beginn des Sb-Anhangs am 28/01/2013 16:56:02.

Fertiger Sb-Anhang am 28/01/2013 16:56:02.

CathalMF
quelle
1
Wenn der String Builder so mächtig ist, warum gibt es dann einen String? Warum löschen wir String nicht komplett aus? Ich habe diese Frage gestellt, damit Sie mir den NUTZEN von String über StringBuilder
Unbreakable
-2

StringBuilder bietet vom Standpunkt des Speichers aus eine bessere Leistung. Bei der Verarbeitung kann der Unterschied in der Ausführungszeit vernachlässigbar sein.

Entwicklung von Chris
quelle