C# System.Reactive 特性

博客主要介绍了Scheduler的用法,指出Scheduler.CurrentThread不一定在原线程运行,若当前线程忙会新启动线程。还提到async定义的方法调用时在本线程,但await代码可能在新线程。此外,探讨了实现线程套间功能,Root Task及await后的新Task可使用各自的TaskScheduler创建。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Scheduler的用法

            Task.Run(async  () =>
            {
                Console.WriteLine("Task.Run! " + Thread.CurrentThread.ManagedThreadId.ToString());

                Observable.Timer(TimeSpan.FromSeconds(3)).ObserveOn(Scheduler.CurrentThread).Subscribe(a =>
                {
                    Console.WriteLine("Observable.Timer! " + Thread.CurrentThread.ManagedThreadId.ToString());
                });

                //while(true)
                //{
                //    Thread.Sleep(1000);
                //}
                await subject;

                Console.WriteLine("Task.Run! end");
            });

Scheduler.CurrentThread本以为其是就在当前是线程运行,但是如果当前线忙,其还是会新启动了一个线程,以保证其能第一时间运行。

可以看到其不一定能保证是在原线程上运行。对于UniRX应该是要保证其在UI线程上运行的。

通过async定义的方法,只是说明其是一个里面使用到了Task或者线程的方法,方法调用时还是在本线程调用的。

但一个方法中,await的代码可能是在一个新的线程里运行的。。。

以下这个方法在Core中不好用。

TaskScheduler.FromCurrentSynchronizationContext();

https://docs.microsoft.com/en-us/dotnet/api/system.threading.tasks.taskscheduler?redirectedfrom=MSDN&view=netframework-4.8#Sync

目前看要实现线程套间的功能,几个Root Task可以使用的各自的TaskScheduler来进行创建。

Await之后,使用的新的Task也是使用同一个TaskScheduler来创建的。

这样可以通过TaskScheduler.Id做一些标识上的东西。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值