Прочитать на английском

Поделиться через


Enumerable.Count Метод

Определение

Возвращает количество элементов в последовательности.

Перегрузки

Count<TSource>(IEnumerable<TSource>)

Возвращает количество элементов в последовательности.

Count<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>)

Возвращает число, представляющее количество элементов последовательности, удовлетворяющих заданному условию.

Count<TSource>(IEnumerable<TSource>)

Исходный код:
Count.cs
Исходный код:
Count.cs
Исходный код:
Count.cs

Возвращает количество элементов в последовательности.

C#
public static int Count<TSource> (this System.Collections.Generic.IEnumerable<TSource> source);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IEnumerable<TSource>

Последовательность, элементы которой требуется подсчитать.

Возвращаемое значение

Число элементов во входной последовательности.

Исключения

source имеет значение null.

Количество элементов в source больше, чем Int32.MaxValue.

Примеры

В следующем примере кода показано, как использовать для Count<TSource>(IEnumerable<TSource>) подсчета элементов в массиве.

C#
string[] fruits = { "apple", "banana", "mango", "orange", "passionfruit", "grape" };

try
{
    int numberOfFruits = fruits.Count();
    Console.WriteLine(
        "There are {0} fruits in the collection.",
        numberOfFruits);
}
catch (OverflowException)
{
    Console.WriteLine("The count is too large to store as an Int32.");
    Console.WriteLine("Try using the LongCount() method instead.");
}

// This code produces the following output:
//
// There are 6 fruits in the collection.

Комментарии

Если тип source реализует ICollection<T>, эта реализация используется для получения количества элементов. В противном случае этот метод определяет количество.

Используйте метод , LongCount если вы ожидаете и хотите, чтобы результат был больше MaxValue.

В синтаксисе Aggregate Into Count() выражения запроса Visual Basic предложение преобразуется в вызов Count.

См. также раздел

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Count<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>)

Исходный код:
Count.cs
Исходный код:
Count.cs
Исходный код:
Count.cs

Возвращает число, представляющее количество элементов последовательности, удовлетворяющих заданному условию.

C#
public static int Count<TSource> (this System.Collections.Generic.IEnumerable<TSource> source, Func<TSource,bool> predicate);

Параметры типа

TSource

Тип элементов source.

Параметры

source
IEnumerable<TSource>

Последовательность, элементы которой требуется проверить и подсчитать.

predicate
Func<TSource,Boolean>

Функция для проверки каждого элемента на соответствие условию.

Возвращаемое значение

Число, представляющее количество элементов последовательности, удовлетворяющих условию функции предиката.

Исключения

Параметр source или predicate имеет значение null.

Количество элементов в source больше, чем Int32.MaxValue.

Примеры

В следующем примере кода показано, как использовать для Count<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>) подсчета элементов в массиве, удовлетворяющих условию.

C#
class Pet
{
    public string Name { get; set; }
    public bool Vaccinated { get; set; }
}

public static void CountEx2()
{
    Pet[] pets = { new Pet { Name="Barley", Vaccinated=true },
                   new Pet { Name="Boots", Vaccinated=false },
                   new Pet { Name="Whiskers", Vaccinated=false } };

    try
    {
        int numberUnvaccinated = pets.Count(p => p.Vaccinated == false);
        Console.WriteLine("There are {0} unvaccinated animals.", numberUnvaccinated);
    }
    catch (OverflowException)
    {
        Console.WriteLine("The count is too large to store as an Int32.");
        Console.WriteLine("Try using the LongCount() method instead.");
    }
}

// This code produces the following output:
//
// There are 2 unvaccinated animals.

Комментарии

Если тип source реализует ICollection<T>, эта реализация используется для получения количества элементов. В противном случае этот метод определяет количество.

Метод следует использовать, LongCount если вы ожидаете и хотите, чтобы результат был больше MaxValue.

В синтаксисе Aggregate Into Count() выражения запроса Visual Basic предложение преобразуется в вызов Count.

См. также раздел

Применяется к

.NET 9 и другие версии
Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0