Конкатенация Времени Компиляции C# Для Строковых Констант

выполняет ли C# оптимизацию времени компиляции для конкатенации постоянных строк? Если да, то как мой код должен быть написан, чтобы воспользоваться этим?

пример: как они сравниваются во время выполнения?

Console.WriteLine("ABC" + "DEF");

const string s1 = "ABC";
Console.WriteLine(s1 + "DEF");

const string s1 = "ABC";
const string s2 = s1 + "DEF";
Console.WriteLine(s2);

2 ответов


Да, это делает. Вы можете проверить это, используя ildasm или рефлектор для того чтобы проверить код.

static void Main(string[] args) {
    string s = "A" + "B";
    Console.WriteLine(s);
}

переведен на

.method private hidebysig static void  Main(string[] args) cil managed {
    .entrypoint
    // Code size       17 (0x11)
    .maxstack  1
    .locals init ([0] string s)
    IL_0000:  nop
    IL_0001:  ldstr      "AB" // note that "A" + "B" is concatenated to "AB"
    IL_0006:  stloc.0
    IL_0007:  ldloc.0
    IL_0008:  call       void [mscorlib]System.Console::WriteLine(string)
    IL_000d:  nop
    IL_000e:  br.s       IL_0010
    IL_0010:  ret
} // end of method Program::Main

есть что-то еще более интересное, но о том, что происходит. Если в сборке имеется строковый литерал, среда CLR создаст только один объект для всех экземпляров этого же литерала в сборке.

таким образом:

static void Main(string[] args) {
    string s = "A" + "B";
    string t = "A" + "B";
    Console.WriteLine(Object.ReferenceEquals(s, t)); // prints true!
}

будет печатать "True" на консоли! Эта оптимизация называется интернировании строк.


по данным отражатель:

Console.WriteLine("ABCDEF");
Console.WriteLine("ABCDEF");
Console.WriteLine("ABCDEF");

даже в конфигурации отладки.