_fbClient.GetCompleted += new EventHandler<FacebookApiEventArgs>(OnFetchPageNotification); _fbClient.GetAsync(_kNotificationPath,new Dictionary<string,object> { { "access_token",_kPageAccesstoken } });
object = await _fbClient.GetAsync(_kNotificationPath,_kPageAccesstoken } });
我也有CTP安装和任务并行库.
解决方法
Async CTP附带了一个文档,该文档描述了如何使每个现有模式适应基于任务的异步模式.它说基于事件的一个更可变,但确实给出了一个例子:
public static Task<string> DownloadStringAsync(Uri url) { var tcs = new taskcompletionsource<string>(); var wc = new WebClient(); wc.DownloadStringCompleted += (s,e) => { if (e.Error != null) tcs.TrySetException(e.Error); else if (e.Cancelled) tcs.TrySetCanceled(); else tcs.TrySetResult(e.Result); }; wc.DownloadStringAsync(url); return tcs.Task; }
在被包装的原始函数是DownloadStringAsync的情况下,参数与传递给该函数的参数匹配,而DownloadStringCompleted是被监视的事件.
(同一文档似乎可以下载here – 上面的示例(以及更多描述)来自“任务和基于事件的异步模式(EAP)”)
原文地址:https://www.jb51.cc/csharp/97683.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。