Dav*_*vid 7 c# ienumerator system.reactive
我很好奇是否IEnumerable与IObservable引擎盖下有什么不同.我分别理解了pull和push模式但是C#在内存等方面如何通知订阅者(对于IObservable)它应该在内存中接收下一位数据来处理?观察到的实例如何知道它有一个数据的变化推送到订阅者.
我的问题来自于我正在从文件中读取行的测试.该文件总共约为6Mb.
标准时间:4.7s,行:36587
Rx拍摄时间:0.68秒,行:36587
Rx如何能够大规模地改进文件中每条线的正常迭代?
private static void ReadStandardFile()
{
var timer = Stopwatch.StartNew();
var linesProcessed = 0;
foreach (var l in ReadLines(new FileStream(_filePath, FileMode.Open)))
{
var s = l.Split(',');
linesProcessed++;
}
timer.Stop();
_log.DebugFormat("Standard Time Taken: {0}s, lines: {1}",
timer.Elapsed.ToString(), linesProcessed);
}
private static void ReadRxFile()
{
var timer = Stopwatch.StartNew();
var linesProcessed = 0;
var query = ReadLines(new FileStream(_filePath, FileMode.Open)).ToObservable();
using (query.Subscribe((line) =>
{
var s = line.Split(',');
linesProcessed++;
}));
timer.Stop();
_log.DebugFormat("Rx Time Taken: {0}s, lines: {1}",
timer.Elapsed.ToString(), linesProcessed);
}
private static IEnumerable<string> ReadLines(Stream stream)
{
using (StreamReader reader = new StreamReader(stream))
{
while (!reader.EndOfStream)
yield return reader.ReadLine();
}
}
Run Code Online (Sandbox Code Playgroud)
我的预感是你所看到的反映操作系统缓存文件的行为.我想如果你颠倒了调用的顺序,你会看到类似的速度差异,只是换了.
您可以通过执行一些预热运行或通过File.Copy在测试每个文件之前将输入文件复制到临时文件来改进此基准测试.这样文件就不会"热",你会得到一个公平的比较.