c# – 为什么Crossthreading这样工作?

前端之家收集整理的这篇文章主要介绍了c# – 为什么Crossthreading这样工作?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
解决

似乎奥利弗是对的.经过几次尝试,我得到了异常,在调试模式我得到它肯定.所以这一切都要关于时间安排.你也应该检查Matthew wattsons的答案;)

首先要说明一点我的困惑.

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Threading;

namespace testCrossThreading
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            new Thread(ThreadJob).Start();
        }

        void ThreadJob()
        {
            //label1.Text = "1";
            changeText(label1,"1");
        }

        void changeText(Label L,String message)
        {
            L.Text = message;
        }
    }
}

所以现在我的问题:如果我取消注释label1.Text =“1”;在函数“ThreadJob”中,我按预期得到一个十字线程异常.
但是如果我把它留下来,就像这个例子表明它是有效的.但为什么?
函数由子线程调用,我不调用任何东西.所以它仍然是子线程,而不是改变标签imo的文本的GUI线程.还是我错过了什么?

我会这样写

void ThreadJob()
        {
            Action a = () => label1.Text = "1";
            this.Invoke(a);
        }

解决方法

我认为这只是一个时间问题.如果您尝试从非gui线程更新gui元素,则可以抛出跨线程异常.甚至可以通过调用禁止整个跨线程的异常
Form.CheckForIllegalCrossThreadCalls = false;

但是在异常消失之后,进一步的行为是未定义的,可能导致非常微妙的错误.所以将异常作为一个代码气味的提示,但要注意的是,有时异常不会被抛出,即使它应该是.

猜你在找的C#相关文章