最初のイベントが受信されたときにデリゲートが呼び出され、その後のイベントが受信された場合は 1 秒間呼び出されないように、イベント ストリームを効果的に調整したいと考えています。そのタイムアウト (1 秒) が経過した後、後続のイベントが受信された場合は、デリゲートが呼び出されるようにします。
Reactive Extensions を使用してこれを行う簡単な方法はありますか?
サンプルコード:
static void Main(string[] args)
{
Console.WriteLine("Running...");
var generator = Observable
.GenerateWithTime(1, x => x <= 100, x => x, x => TimeSpan.FromMilliseconds(1), x => x + 1)
.Timestamp();
var builder = new StringBuilder();
generator
.Sample(TimeSpan.FromSeconds(1))
.Finally(() => Console.WriteLine(builder.ToString()))
.Subscribe(feed =>
builder.AppendLine(string.Format("Observed {0:000}, generated at {1}, observed at {2}",
feed.Value,
feed.Timestamp.ToString("mm:ss.fff"),
DateTime.Now.ToString("mm:ss.fff"))));
Console.ReadKey();
}
現在の出力:
Running...
Observed 064, generated at 41:43.602, observed at 41:43.602
Observed 100, generated at 41:44.165, observed at 41:44.602
しかし、私は観察したいです(タイムスタンプは明らかに変わります)
Running...
Observed 001, generated at 41:43.602, observed at 41:43.602
....
Observed 100, generated at 41:44.165, observed at 41:44.602