我不太擅长异步编程,所以问题可能是低级的。
我在 ASP.NET MVC 4 Dev 上使用 Async CTP 创建了如下异步方法。预览:
public class Movie
{
public string Title { get; set; }
public string Url { get; set; }
public string BoxArtUrl { get; set; }
}
public class MovieM {
public IEnumerable<Movie> M2009 { get; set; }
public IEnumerable<Movie> M2010 { get; set; }
public IEnumerable<Movie> M2011 { get; set; }
}
public class HomeController : AsyncController {
public async Task<ActionResult> GetMoviesM() {
var profiler = MiniProfiler.Current; // it's ok if this is null
var pageSize = 1000;
var imageCount = 0;
using (profiler.Step("Start pulling data (Async) and return it")) {
var m2009 = await QueryMoviesAsync(2009, imageCount, pageSize);
var m2010 = await QueryMoviesAsync(2010, imageCount, pageSize);
var m2011 = await QueryMoviesAsync(2011, imageCount, pageSize);
return View(new MovieM {
M2009 = m2009,
M2010 = m2010,
M2011 = m2011
});
}
}
XNamespace xa = "http://www.w3.org/2005/Atom";
XNamespace xd = "http://schemas.microsoft.com/ado/2007/08/dataservices";
XNamespace xm = "http://schemas.microsoft.com/ado/2007/08/dataservices/metadata";
string query = "http://odata.netflix.com/Catalog/Titles?$filter=ReleaseYear eq {0}&$skip={1}&$top={2}&$select=Url,BoxArt";
async Task<IEnumerable<Movie>> QueryMoviesAsync(int year, int first, int count) {
var client = new WebClient();
var url = String.Format(query, year, first, count);
var data = await client.DownloadStringTaskAsync(new Uri(url));
var movies =
from entry in XDocument.Parse(data).Descendants(xa + "entry")
let properties = entry.Element(xm + "properties")
select new Movie
{
Title = (string)entry.Element(xa + "title"),
Url = (string)properties.Element(xd + "Url"),
BoxArtUrl = (string)properties.Element(xd + "BoxArt").Element(xd + "LargeUrl")
};
return movies.AsEnumerable();
}
}
代码工作得很好。当我们在桌面应用程序(例如 WPF 应用程序)上运行相同的功能时,我们可以看到明显的性能差异。UI 没有被阻止,数据在可用时会立即推送到屏幕上。
但是在 Web 应用程序上,我真的看不出有什么不同。我还创建了与同步相同的功能,它们几乎相同。
我想知道的是:
- 我在具有Intel Core 2 Duo CPU T5750 2.00GHz的机器上运行此应用程序。处理器数量会影响 C# 上异步线程的性能吗?
- 从 Web 应用程序的角度来看,我在这里做错了吗?