Fla*_*don 4 c# system.reactive
我想弄清楚如何处理序列中的n 个缓冲项目,然后在处理下 n 个项目之前等待t秒?
这是我尝试做的粗略形式,使用 Thread.Sleep()。我想避免 Thread.Sleep() 并正确执行。
static void Main(string[] args)
{
var t = Observable.Range(0, 100000);
var query = t.Buffer(20);
query.ObserveOn(NewThreadScheduler.Default)
.Subscribe(x => DoStuff(x));
Console.WriteLine("Press ENTER to exit");
Console.ReadLine();
}
static void DoStuff(IList<int> list)
{
Console.WriteLine(DateTime.Now);
foreach (var value in list)
{
Console.WriteLine(value);
}
Thread.Sleep(TimeSpan.FromSeconds(10));
}
Run Code Online (Sandbox Code Playgroud)
任何人都可以帮助我找到一种更 RX 的方式来做到这一点吗?
谢谢
闪光
// Instantiate this once, we'll use it in a closure multiple times.
var delay = Observable.Empty<int>().Delay(TimeSpan.FromMilliseconds(10));
// start with a source of individual items to be worked.
Observable.Range(0, 100000)
// Create batches of work.
.Buffer(20)
// Select an observable for the batch of work, and concat a delay.
.Select(batch => batch.ToObservable().Concat(delay))
// Concat those together and form a "process, delay, repeat" observable.
.Concat()
// Subscribe!
.Subscribe(Console.WriteLine);
// Make sure we wait for our work to be done.
// There are other ways to sync up, like async / await.
Console.ReadLine();
Run Code Online (Sandbox Code Playgroud)
或者,您也可以使用 async/await 进行同步:
static IObservable<int> delay = Observable.Empty<int>().Delay(TimeSpan.FromMilliseconds(100));
static async Task Run()
{
await Observable.Range(0, 1000)
.Buffer(20)
.Select(batch => batch.ToObservable().Concat(delay))
.Concat()
.Do(Console.WriteLine)
.LastOrDefaultAsync();
}
Run Code Online (Sandbox Code Playgroud)
这不是delayobservable 一个绝妙的技巧吗?它起作用是因为 OnCompleted 就像 OnNext 一样被延迟了!