微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用Parallel BeginInvoke时,Invoke不是–c#4.0

当我在AddListBoxItem函数中使用invoke时,如下所示,软件变得无法响应并冻结,但如果我使用BeginInvoke它可以工作.为什么会这样?

visual studio 2010,C#4.0

private void button2_Click(object sender,EventArgs e)
{
    var watch = Stopwatch.StartNew();
    Parallel.For(2,20,(i) =>
    {
        var result = SumRootN(i);
        AddListBoxItem("root " + i + " : " + result);
    });
    AddListBoxItem(watch.ElapsedMilliseconds.ToString());            
}

private delegate void AddListBoxItemDelegate(object item);

private void AddListBoxItem(object item)
{
    if (this.listBox1.Invokerequired)
    {
        this.listBox1.Invoke(new AddListBoxItemDelegate(this.AddListBoxItem),item);
    }
    else
    {
        this.listBox1.Items.Add(item);
    }
}

解决方法

您的UI线程将等待Parallel.For在继续之前完成.这意味着它不能处理任何进一步的UI消息,直到它完成.

现在,当工作线程调用Invoke时,它们会等待UI线程在继续之前处理该委托.所以他们正在等待UI线程获得自由,基本上.

因此,您有一个死锁 – UI线程正在等待正在等待UI线程的任务…… BeginInvoke有效,因为任务线程不会等待在UI线程中处理委托.

我建议你不要在UI线程中调用Parallel.For来开始.您将阻止UI直到它完成,这不是一个好主意.在后台线程中完成整个事情 – 如果你愿意,你仍然可以使用Invoke,并且在进行计算时,UI仍然会响应.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐