我正在尝试使用 Rx 在 Windows Phone 7.5 上为 linq-to-sql 编写异步 DataContext。我的想法是在DataContext中定义一个方法:
IObservable<List<Fact>> GetFacts(Func<MyDataContext, IQueryable<Fact>> selector)
{
var selectFacts = Observable.FromAsyncPattern<MyDataContext, IQueryable<Fact>>(selector.BeginInvoke, selector.EndInvoke);
return selectFacts(db).Select((query) => query.ToList());// db variable is MyDataContext instance, and is not null during the call or later
}
然后应该从客户端代码调用此方法,如下所示:
var q = GetFacts((database) => from item in database.Facts select item)
.ObserveOnDispatcher()
.Do((facts) => MessageBox.Show(facts.Count.ToString()))
.Subscribe();
我面临的问题很奇怪。当from item in database.Facts select item
实际调用客户端选择器 ( )时,database
其上下文中的参数为空!因此,我显然得到了 NullReferenceException。但是当selectFacts
被调用时,该db
值是非空的,并且指向正确的实例。
这个事实有什么解释吗?如何克服它?
提前致谢。