本来我想知道是否ToList比使用的构造函数分配的内存List<T>这需要一个IEnumerable<T>(没有区别).
出于测试目的,我曾经Enumerable.Range创建了一个源数组,我可以用它来创建List<int>via 1. ToList和2. constructor的实例.两者都在创建副本.
这就是我注意到以下内存消耗的巨大差异:
Enumerable.Range(1, 10000000) 要么 Enumerable.Range(1, 10000000).ToArray()当我使用第一个并调用ToList生成的对象时,内存比数组(38,26MB/64MB)大约多60%.
问:推理错误的原因是什么?
var memoryBefore = GC.GetTotalMemory(true);
var range = Enumerable.Range(1, 10000000);
var rangeMem = GC.GetTotalMemory(true) - memoryBefore; // negligible
var list = range.ToList();
var memoryList = GC.GetTotalMemory(true) - memoryBefore - rangeMem;
String memInfoEnumerable = String.Format("Memory before: {0:N2} MB List: {1:N2} MB"
, (memoryBefore / 1024f) / 1024f
, (memoryList / 1024f) / 1024f);
// …Run Code Online (Sandbox Code Playgroud) 可能重复:
c#Leaner初始化int数组的方法
基本上我想知道是否有比下面显示的更有效的代码
private static int[] GetDefaultSeriesArray(int size, int value)
{
int[] result = new int[size];
for (int i = 0; i < size; i++)
{
result[i] = value;
}
return result;
}
Run Code Online (Sandbox Code Playgroud)
大小可以从10到150000不等.对于小阵列不是问题,但应该有更好的方法来做到这一点.我正在使用VS2010(.NET 4.0)