如何用BeginInvoke方法解决SetCurrentCellAddressCore 异常

实现效果就是,双击单元格修改之后,数据要及时更新到数据库,然后把更新后的数据重新绑定到控件中,但是在重新绑定数据的时候会报错,错误信息为:原因是它导致对 SetCurrentCellAddressCore 函数的可重入调用。通过网上搜索,用BeginInvoke解决了这个异常。

   public delegate void MyInvoke();
   public void DoWork()
        {
          MyInvoke mi = new MyInvoke(DataBind);
    this.BeginInvoke(mi);
       }

数据绑定的时候调用DoWork()这个方法就可以了!其中DataBind就是数据绑定的方法!


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你在非UI线程上尝试使用 Invoke 或 BeginInvoke 方法时,可能会出现 "視窗控制代碼建立後才能呼叫控制項上的 Invoke 或 BeginInvoke" 异常。这是因为这些方法只能在创建相应控件的UI线程上调用。 为了解决这个问题,你可以使用 SynchronizationContext 类来在非UI线程上执行UI操作。下面是一个示例代码,展示了如何使用 SynchronizationContext 来解决这个问题: ```csharp using System; using System.Threading; using System.Threading.Tasks; using System.Windows.Forms; public class Program { private static ProgressBar progressBar; private static SynchronizationContext synchronizationContext; public static void Main() { Form form = new Form(); progressBar = new ProgressBar(); form.Controls.Add(progressBar); synchronizationContext = SynchronizationContext.Current; // 创建一个线程来模拟任务的进度更新 Thread thread = new Thread(UpdateProgress); thread.Start(); // 显示窗体 Application.Run(form); } private static void UpdateProgress() { for (int i = 0; i <= 100; i++) { // 使用 SynchronizationContext.Post 方法在 UI 线程上执行更新操作 synchronizationContext.Post(new SendOrPostCallback(state => { progressBar.Value = (int)state; }), i); // 模拟任务的延迟 Thread.Sleep(100); } } } ``` 在上述代码中,我们通过在 Main 方法中获取当前的 SynchronizationContext 对象来捕获UI线程的上下文。然后,在 UpdateProgress 方法中,我们使用 SynchronizationContext 的 Post 方法来在UI线程上执行进度更新操作。这样就可以避免在非UI线程上使用 Invoke 或 BeginInvoke 方法时出现异常。 通过这种方式,你可以在非UI线程上安全地更新UI控件的值,而无需直接使用 Invoke 或 BeginInvoke 方法。注意,这种方法也适用于使用 Task 或其他异步操作的情况。 希望这个代码示例能帮助你解决 "視窗控制代碼建立後才能呼叫控制項上的 Invoke 或 BeginInvoke" 异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值