A menudo utilizo este recursiva 'visitante' en Fa #Escribir el F # visitante recurrente de la carpeta en C# - SEC vs IEnumerable
let rec visitor dir filter=
seq { yield! Directory.GetFiles(dir, filter)
for subdir in Directory.GetDirectories(dir) do yield! visitor subdir filter}
Recientemente he comenzado a trabajar en la implementación de algunas # funcionalidad F en C#, y estoy tratando de reproducir esto como IEnumerable, pero estoy teniendo dificultades para conseguir más allá de esto:
static IEnumerable<string> Visitor(string root, string filter)
{
foreach (var file in Directory.GetFiles(root, filter))
yield return file;
foreach (var subdir in Directory.GetDirectories(root))
foreach (var file in Visitor(subdir, filter))
yield return file;
}
lo que no entiendo es por eso que tengo que hacer un doble foreach en la versión C# para la recursividad, pero no en F # ... ¿El seq {} hace implícitamente un 'concat'?
Entonces, ¿podría hacer un .SelectMany para reproducir esto en C#? – Benjol
El "retorno de rendimiento" de C# solo puede devolver un artículo a la vez, así que estás atascado con tus engaños, me temo. – Sunlight