C#异步方法仍然挂起UI

我有这两种方法,我想运行异步以保持UI响应.但是,它仍然挂在UI上.有什么建议么?
async void DoScrape()
    {
        var Feed = new Feed();

        var results = await Feed.GetList();
        foreach (var itemObject in results)
        {
            var item = new ListViewItem(itemObject.Title);
            item.SubItems.Add(itemObject.Link);
            item.SubItems.Add(itemObject.Description);
            LstResults.Items.Add(item);
        }
    }


    public class Feed
    {
        async public Task<List<ItemObject>> GetList()
        {
            var client = new WebClient();
            string content = await client.DownloadStringTaskAsync(new Uri("anyUrl"));
            var lstItemObjects = new List<ItemObject>();
            var Feed = new XmlDocument();
            Feed.LoadXml(content);
            var nodes = Feed.GetElementsByTagName("item");

            foreach (XmlNode node in nodes)
            {
                var tmpItemObject = new ItemObject();
                var title = node["title"];
                if (title != null) tmpItemObject.Title = title.InnerText;
                var link = node["link"];
                if (link != null) tmpItemObject.Link = link.InnerText;
                var description = node["description"];
                if (description != null) tmpItemObject.Description = description.InnerText;
                lstItemObjects.Add(tmpItemObject);
            }
            return lstItemObjects;
        }
    }

解决方法

我怀疑DownloadStringTaskAsync依赖于较低级别的 HttpWebRequest.BeginGetResponse.在这种情况下,已知Web请求的设置不是完全异步的.令人沮丧(坦率地说,愚蠢地)异步WebRequest的DNS查找阶段是同步执行的,因此是阻止.我怀疑这可能是你正在观察的问题.

以下转载文档中的警告:

07001

你有两个选择:

>从工作线程启动请求(并且在高负载下,由于阻塞行为而导致ThreadPool的饥饿风险)
(严格)在触发请求之前执行编程DNS查找.这可以异步地完成.希望该请求将使用缓存的DNS查找.

我们去了实现我们自己的正确异步HTTP库的第三(和昂贵)选项,以获得体面的吞吐量,但在您的情况下可能会有点极端;

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...