ho fatto un breve test su instantianting un array utilizzando la sintassi si descrive e trovato che l'istanziazione con valori non predefiniti richiedeva circa 2,2 volte più dell'istantianizzazione con i valori predefiniti.
Quando passavo e creavo un'istanza con valori predefiniti, ci vuole circa lo stesso tempo.
Infatti, quando ho guardato il decompilare, sembra che ciò che accade è l'array inizializzato, e quindi viene popolato con qualsiasi valore che non sia il default.
Instantiating con valori non predefiniti:
bool[] abPrimes = new[] {
true, true
};
0000007e mov edx,2
00000083 mov ecx,79114A46h
00000088 call FD3006F0
0000008d mov dword ptr [ebp-64h],eax
00000090 mov eax,dword ptr [ebp-64h]
00000093 mov dword ptr [ebp-54h],eax
00000096 mov eax,dword ptr [ebp-54h]
00000099 cmp dword ptr [eax+4],0
0000009d ja 000000A4
0000009f call 76A9A8DC
000000a4 mov byte ptr [eax+8],1
000000a8 mov eax,dword ptr [ebp-54h]
000000ab cmp dword ptr [eax+4],1
000000af ja 000000B6
000000b1 call 76A9A8DC
000000b6 mov byte ptr [eax+9],1
000000ba mov eax,dword ptr [ebp-54h]
000000bd mov dword ptr [ebp-40h],eax
un'istanza con valori di default:
bool[] abPrimes2 = new[] {
false, false
};
000000c0 mov edx,2
000000c5 mov ecx,79114A46h
000000ca call FD3006F0
000000cf mov dword ptr [ebp-68h],eax
000000d2 mov eax,dword ptr [ebp-68h]
000000d5 mov dword ptr [ebp-54h],eax
000000d8 mov eax,dword ptr [ebp-54h]
000000db mov dword ptr [ebp-5Ch],eax
Interessante. Mi chiedo se questo approccio di "cancellazione della memoria" all'inizializzazione dell'array sia uno dei motivi per cui le struct non supportano i costruttori predefiniti di default o gli inizializzatori dei membri. Complicerebbe l'inizializzazione dell'array. – LBushkin
Sì, questo è molto. In effetti, le strutture in IL * do * supportano i costruttori senza parametri, ma verranno chiamate solo in determinate situazioni. –
Vedere http://msmvps.com/blogs/jon_skeet/archive/2008/12/10/value-types-and-parameterless-constructors.aspx per ulteriori informazioni. –