I made a quick test and interning of strings does not seem to save them from scanning by GC. At least not in .NET 4.5 64 bit.
class Program
{
static void Main(string[] args)
{
for (int i = 0; i < 20000000; ++i)
{
string s = i.ToString("X");
string.Intern(s);
}
GC.Collect(3, GCCollectionMode.Forced, true);
long t1 = Stopwatch.GetTimestamp();
GC.Collect(3, GCCollectionMode.Forced, true);
long t2 = Stopwatch.GetTimestamp();
Console.WriteLine((double)(t2 - t1) / Stopwatch.Frequency);
}
}
This benchmark returns 0.23s on an i5 3570k. If the strings are put into an array instead of interning, it returns 0.26s. If the strings are interned and created via (i % 10).ToString()
, i.e. there's a small number of different instances, the benchmark returns microseconds.
So sadly this is not a way to bypass garbage collection. I think C# should have some way of marking strings as persistent and stop the runtime wasting time on scanning them.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…