String Concatenation in C# Benchmark

datesabato 31 ottobre 2009 alle 16.12  - posted by Manuel Scapolan in C#

Ci sono diversi modi per concatenare una stringa in C# : con String.Concat,  utilizzando uno StringBuilder, con String.Format oppure ricorrendo all'overloading dell'operatore +. Spinto dalla curiosità di sapere quale di questi modi fosse il più performante ho realizzato un semplice test:

using System;
using System.Text;
using System.Diagnostics;
 
public class Program
{
   static void Main(string[] args)
   {
      Console.WriteLine("String concatenation benchmark");
      Console.WriteLine("------------------------------");
      Console.WriteLine("Plus operator: " + StringPlusOperatorTest());
      Console.WriteLine("String.Format: " + StringFormatTest());
      Console.WriteLine("String.Concat: " + StringConcatTest());
      Console.WriteLine("StringBuilder: " + StringBuilderTest());
      Console.ReadLine();
   }
   
   private static string StringPlusOperatorTest()
   {
      Stopwatch sw = new Stopwatch();
      sw.Start();
      string result = String.Empty;
      for (int i = 0; i < 10000000; i++)
      {
      result = i + " Nel mezzo del cammin di nostra vita, " 
            + "mi ritrovai per una selva oscura" 
            + " ché la diritta via era smarrita.";
      }
      sw.Stop();
      TimeSpan ts = sw.Elapsed;
      return String.Format("{0:00}:{1:00}:{2:00}.{3:00}", 
         ts.Hours, ts.Minutes, ts.Seconds,
         ts.Milliseconds / 10);
   }
 
   private static string StringFormatTest()
   {
      Stopwatch sw = new Stopwatch();
      sw.Start();
      string result = String.Empty;
      for (int i = 0; i < 10000000; i++)
      {
         result = String.Format("{0}{1}{2}{3}", 
            i, " Nel mezzo del cammin di nostra vita, ", 
            "mi ritrovai per una selva oscura", 
            " ché la diritta via era smarrita.");
      }
      sw.Stop();
      TimeSpan ts = sw.Elapsed;
      return String.Format("{0:00}:{1:00}:{2:00}.{3:00}", 
         ts.Hours, ts.Minutes, ts.Seconds,
         ts.Milliseconds / 10);
   }
 
   private static string StringConcatTest()
   {
      Stopwatch sw = new Stopwatch();
      sw.Start();
      string result = String.Empty;
      for (int i = 0; i < 10000000; i++)
      {
         result = String.Concat(i, 
            " Nel mezzo del cammin di nostra vita, ", 
            "mi ritrovai per una selva oscura", 
            " ché la diritta via era smarrita.");
      }
      sw.Stop();
      TimeSpan ts = sw.Elapsed;
      return String.Format("{0:00}:{1:00}:{2:00}.{3:00}",
         ts.Hours, ts.Minutes, ts.Seconds,
         ts.Milliseconds / 10);
   }
 
   private static string StringBuilderTest()
   {
      Stopwatch sw = new Stopwatch();
      sw.Start();
      for (int i = 0; i < 10000000; i++)
      {
         StringBuilder sb = new StringBuilder();
         sb.Append(i);
         sb.Append(" Nel mezzo del cammin di nostra vita, ");
         sb.Append("mi ritrovai per una selva oscura");
         sb.Append(" ché la diritta via era smarrita.");
      }
      sw.Stop();
      TimeSpan ts = sw.Elapsed;
      return String.Format("{0:00}:{1:00}:{2:00}.{3:00}", 
         ts.Hours, ts.Minutes, ts.Seconds,
         ts.Milliseconds / 10);
   }

Il test consiste nel concatenare tre stringhe più un contatore. Data la semplicità dell'operazione per avere dei risultati misurabili ho dovuto inserire l'operazione in un ciclo for. Dai risultati visibili nell'immagine qui sotto si può notare come l'operatore + sia il più veloce seguito dal metodo String.Concat e a grande distanza dagli altri due metodi...

 

String Concatenation Benchmark

Se però consideriamo una concatenazione con più stringhe (42 per la precisione) otteniamo i risultati visibili nell'immagine sottostante. L'operatore + è ancora il migliore, ma il metodo String.Concat peggiora notevolemente forse per il numero cospicuo di parametri.

 

String Concatenation Benchmark

Per quanto possa essere misurabile e percepita dall'utente la differenza di performance questo test conferma una banalità, usare String.Concat per la concatenazione di stringhe e String.Format per la formattazione. :-)

tagsTags: ,

Commenti chiusi

About me

manuel scapolanSono un consulente informatico. Nel 2004 terminati gli studi in Ingegneria Informatica (1° livello), ho iniziato come freelance collaborando con una ditta di consulenza informatica ed una agenzia di marketing e comunicazione nello sviluppo di applicazioni web. Attualmente divido il lavoro di sviluppatore e progettista web con attività di formazione nel settore della programmazione.
View Manuel Scapolan's profile on LinkedIn

Follow me on Follow manuelscapolan on Twitter
Member of:
innova

Calendario


<<  febbraio 2012  >>
lumamegivesado
303112345
6789101112
13141516171819
20212223242526
2728291234
567891011

Disclaimer

Eccetto dove diversamente specificato, i contenuti di questo sito sono rilasciati mediante:
creative commons
Attribuzione: Non commerciale
Condividi allo stesso modo. R.2.5

Books (a bit more about my library)

Domain Driven Design - Eric Evans Applying Domain-Driven Design and Patterns - Jimmy Nilsson Refactoring to Patterns - Joshua Kerievsky Design Patterns -  Erich Gamma, Richard Helm, Ralph Johnson, John M. Vlissides Code Complete Second Edition - Steve McConnell Patterns of Enterprise Application Architecture - Martin Fowler Agile Principles, Patterns, and Practices in C# - Robert C. Martin xUnit Test Patterns - Gerard Meszaros Refactoring - Martin Fowler CLR via C# Second Edition - Jeffrey Richter Framework Design Guidelines: Conventions, Idioms, and Patterns for Reusable .NET Libraries - Krzysztof Cwalina, Brad Abrams Don't make me think! - Steve Krug Bulletproof Ajax - Jeremy Keith

Manuel Scapolan Copyright © 2007 - 2010 - Tutti i diritti riservati - Powered by BlogEngine.NET 1.5.0.7 - silk icons by famfamfam - Time CET