Односторонняя обработка

У меня есть огромный источник (некоторые IEnumerable это проходит через IDbReader строка за строкой), что мне нужно сериализовать, чтобы yaml и десериализовать обратно.
Как я могу избежать сбора всех предметов в памяти?

1 ответ

Вы должны быть в состоянии использовать Сериализатор напрямую для сериализации IEnumerable. Обязательно отключите псевдонимы на сериализаторе, и он должен сериализоваться в потоковом режиме, без предварительной загрузки всего источника:

var serializer = new SerializerBuilder()
    .DisableAliases()
    .Build();

Вы можете увидеть это в действии в следующем коде. Он будет сериализовать первые 100 элементов, затем произойдет сбой с исключением, но вы можете видеть, что первые элементы уже были сериализованы:

using System;
using YamlDotNet.Serialization;
using System.Collections.Generic;
using System.Linq;

public class Program
{
    public static void Main()
    {
        var source = Enumerable.Range(1, 10000).Select(i => {

            if(i == 100) throw new Exception("I'm done");

            return new {
                Index = i,
                Title = "Item " + i
            };
        });

        var serializer = new SerializerBuilder()
            .DisableAliases()
            .Build();

        serializer.Serialize(Console.Out, source);
    }
}

Смотрите его здесь: https://dotnetfiddle.net/Rk1nrx

Другие вопросы по тегам