我正在查看 Roslyn ObjectPool 实现 ( https://github.com/dotnet/roslyn/blob/master/src/Compilers/Core/SharedCollections/ObjectPool%601.cs ),我不明白为什么他们不简单地选择一个 T 数组而是将 T 包装在一个结构中?
[DebuggerDisplay("{Value,nq}")]
private struct Element
{
internal T Value;
}
...
private readonly Element[] _items;
这样做的目的是什么?
最佳答案
这是在设置引用类型的数组项时避免性能问题的常用技巧。数组在 CLR(和 JVM)上是变体。您可以将 string
写入 object[]
。这需要运行时检查您实际上没有将字符串存储到 SomethingElse[]
中。使用该值类型技巧,无需在运行时执行该检查。
关于c# - Roslyn ObjectPool 结构包装器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32628223/