Односторонняя обработка
У меня есть огромный источник (некоторые 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