Kiedy szukałem różnicy między Countem a Countem () , pomyślałem, żeby rzucić okiem na kod źródłowy Count()
. Widziałem następujący fragment kodu, w którym zastanawiam się, dlaczego checked
słowo kluczowe jest konieczne / potrzebne:
int num = 0;
using (IEnumerator<TSource> enumerator = source.GetEnumerator())
{
while (enumerator.MoveNext())
{
num = checked(num + 1);
}
return num;
}
Kod źródłowy:
// System.Linq.Enumerable
using System.Collections;
using System.Collections.Generic;
public static int Count<TSource>(this IEnumerable<TSource> source)
{
if (source == null)
{
ThrowHelper.ThrowArgumentNullException(ExceptionArgument.source);
}
ICollection<TSource> collection = source as ICollection<TSource>;
if (collection != null)
{
return collection.Count;
}
IIListProvider<TSource> iIListProvider = source as IIListProvider<TSource>;
if (iIListProvider != null)
{
return iIListProvider.GetCount(onlyIfCheap: false);
}
ICollection collection2 = source as ICollection;
if (collection2 != null)
{
return collection2.Count;
}
int num = 0;
using (IEnumerator<TSource> enumerator = source.GetEnumerator())
{
while (enumerator.MoveNext())
{
num = checked(num + 1);
}
return num;
}
}
Odpowiedzi:
Ponieważ nie chce zwracać liczby ujemnej w (co jest mało prawdopodobne) zdarzeniu, że w sekwencji jest więcej niż 2 miliardy nieparzystych pozycji - lub nieujemna, ale po prostu zła liczba w (jeszcze bardziej mało prawdopodobnym) przypadku że w sekwencji jest ponad 4 miliardy nieparzystych pozycji.
checked
wykryje stan przepełnienia.źródło
unchecked
; możnachecked
go domyślnie przełączyć na poziomie globalnym za pomocą przełącznika kompilatora - ale szczerze mówiąc rzadko widzę, że jest używany, więc myślę, że błędem jest sugerowanie, że C # jest „zwykle” uruchamiany wchecked
trybie; Należy również zauważyć, żeunsafe
nie ma interakcji zunchecked