List<T>.ConvertAll<TOutput>(Converter<T,TOutput>) Метод

Определение

Преобразует элементы текущего списка List<T> в другой тип и возвращает список преобразованных элементов.

C#
public System.Collections.Generic.List<TOutput> ConvertAll<TOutput> (Converter<T,TOutput> converter);

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

TOutput

Тип элементов массива назначения.

Параметры

converter
Converter<T,TOutput>

Делегат Converter<TInput,TOutput>, преобразующий каждый элемент из одного типа в другой.

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

List<TOutput>

Список List<T> с элементами конечного типа, преобразованными из текущего списка List<T>.

Исключения

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

Примеры

В следующем примере определяется метод с именем PointFToPoint , который преобразует структуру PointF в структуру Point . Затем в примере создается List<T>PointF из структур, создается Converter\<PointF, Point> делегат (Converter(Of PointF, Point) в Visual Basic) для представления PointFToPoint метода и передается делегат в ConvertAll метод . Метод ConvertAll передает каждый элемент входного списка методу PointFToPoint и помещает преобразованные элементы в новый список Point структур. Отображаются оба списка.

C#
using System;
using System.Drawing;
using System.Collections.Generic;

public class Example
{
    public static void Main()
    {
        List<PointF> lpf = new List<PointF>();

        lpf.Add(new PointF(27.8F, 32.62F));
        lpf.Add(new PointF(99.3F, 147.273F));
        lpf.Add(new PointF(7.5F, 1412.2F));

        Console.WriteLine();
        foreach( PointF p in lpf )
        {
            Console.WriteLine(p);
        }

        List<Point> lp = lpf.ConvertAll(
            new Converter<PointF, Point>(PointFToPoint));

        Console.WriteLine();
        foreach( Point p in lp )
        {
            Console.WriteLine(p);
        }
    }

    public static Point PointFToPoint(PointF pf)
    {
        return new Point(((int) pf.X), ((int) pf.Y));
    }
}

/* This code example produces the following output:

{X=27.8, Y=32.62}
{X=99.3, Y=147.273}
{X=7.5, Y=1412.2}

{X=27,Y=32}
{X=99,Y=147}
{X=7,Y=1412}
 */

Комментарии

Converter<TInput,TOutput> это делегат метода, который преобразует объект в целевой тип. Элементы текущего List<T> объекта по отдельности передаются делегату Converter<TInput,TOutput> , а преобразованные элементы сохраняются в новом List<T>объекте .

Текущий List<T> остается неизменным.

Этот метод является операцией O(n), где n — .Count

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

Продукт Версии
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 2.0, 3.0, 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 2.0, 2.1

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