编程语言
首页 > 编程语言> > c# – 异步TaskCompletionSource调用方法两次

c# – 异步TaskCompletionSource调用方法两次

作者:互联网

found this way使用等待通过回调调用异步方法,我在Argotic RSS阅读器库上使用它:

var tcs = new TaskCompletionSource<string>();

EventHandler<SyndicationResourceLoadedEventArgs> feedReaderOnLoaded = null;
feedReaderOnLoaded = (sender, args) =>
                {
                    feedReader.Loaded -= feedReaderOnLoaded;
                    tcs.SetResult(""); // Needed so the await completes
                };
feedReader.Loaded += feedReaderOnLoaded;
feedReader.LoadAsync(new Uri(feed.Url), new object());

await tcs.Task;

// Result is put in a property, rather than returned from the method
var items = feedReader.Channel.Items;

所以这很好用,我得到了我的物品.

我注意到在Fiddler中,两个调用正在对RSS feed的url进行调用.单步执行调试器中的代码后,会在LoadAsync上调用一次,并再次等待tcs.Task.我应该怎么做才能消除其中一个电话?

更新有一个控制台应用程序项目,可以是downloaded from here,演示此行为.

更新我已经改变了我使用Argotic库的方式,因此我使用HttpClient下载RSS提要,然后将内容作为字符串传递给Argotic,现在只生成一个调用.如果有人有任何想法,我仍然想知道为什么它会被召唤两次.

解决方法:

看起来它是feed reader的Async API中的错误/功能.

它执行异步WebRequest以获取提要.
但是,当它处理WebRequest完成时,它会为响应创建一个XmlReader,但实际上使用:
SyndicationEncodingUtility.CreateSafeNavigator(Url,new WebRequestOptions(),null)
从源Url再次(同步)读取它.

Feed本身将在第二次缓存,因此不会造成巨大的开销.

认为可以通过将响应流传递给CreateSafeNavigator来修复它,但也许读取响应流也可以从异步完成中获益.

标签:c,async-await,c-5-0
来源: https://codeday.me/bug/20190709/1413814.html