线程间操作无效:从不是创建控件“textBox1”的线程访问它

本文介绍了一种在不同线程间安全更新Windows Forms中TextBox文本的方法。通过使用Delegate和Invoke方法确保了UI线程和后台线程之间的同步,避免了跨线程访问异常。
private delegate void SetTextCallback(string text);
//在给textBox1.text赋值的地方调用以下方法即可
private void SetText(string text)
{
    // InvokeRequired需要比较调用线程ID和创建线程ID
    // 如果它们不相同则返回true
    if (this.textBox1.InvokeRequired)
    {
        SetTextCallback d = new SetTextCallback(SetText);
        this.Invoke(d, new object[] { text });
    }
    else
    {
        this.textBox1.Text = text;
    }
}
在C#中,当从不创建控件线程访问控件时,会抛出“线程间操作无效: 从不创建控件textBox1’的线程访问它”的异常。以下是几种解决该问题的方法: #### 使用`Invoke`或`BeginInvoke`方法 `Invoke`和`BeginInvoke`方法可用于在创建控件线程上执行代码。`Invoke`是同步的,会阻塞当前线程直到委托执行完毕;`BeginInvoke`是异步的,不会阻塞当前线程。 以下是使用`Invoke`方法的示例代码: ```csharp private delegate void UpdateTextBoxDelegate(string text); private void UpdateTextBox(string text) { if (textBox1.InvokeRequired) { UpdateTextBoxDelegate del = new UpdateTextBoxDelegate(UpdateTextBox); textBox1.Invoke(del, new object[] { text }); } else { textBox1.Text = text; } } private void Func1() { for (int i = 0; i < 5; i++) { UpdateTextBox($"线程{Thread.CurrentThread.ManagedThreadId}执行{i}.\n"); } } ``` #### 使用`Control.CheckForIllegalCrossThreadCalls`属性 将`Control.CheckForIllegalCrossThreadCalls`属性设置为`false`,可以禁用线程间操作的检查。但这种方法不推荐使用,因为它可能会导致程序出现难以调试的问题。 示例代码如下: ```csharp public Form1() { InitializeComponent(); Control.CheckForIllegalCrossThreadCalls = false; } private void Func1() { for (int i = 0; i < 5; i++) { textBox1.Text = textBox1.Text + $"线程{Thread.CurrentThread.ManagedThreadId}执行{i}." + Environment.NewLine; } } ``` #### 使用`Task`和`async/await` 使用`Task`和`async/await`可以更方便地处理异步操作,并且可以避免线程间操作的问题。 示例代码如下: ```csharp private async void Button1_Click(object sender, EventArgs e) { await Task.Run(() => { for (int i = 0; i < 5; i++) { textBox1.Invoke((MethodInvoker)delegate { textBox1.Text = textBox1.Text + $"线程{Thread.CurrentThread.ManagedThreadId}执行{i}." + Environment.NewLine; }); } }); } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值