如何用BeginInvoke方法解决SetCurrentCellAddressCore 异常


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

只是拙于表达,所以把代码贴在这里:

   private void dataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            if (DialogResult.OK == MessageBox.Show("是否要修改", "", MessageBoxButtons.OKCancel))
            {
                Users user = new Users();
                user.UserName = this.dataGridView1.Rows[e.RowIndex].Cells[0].Value.ToString();
                user.Password = this.dataGridView1.Rows[e.RowIndex].Cells[1].Value.ToString();
                string sql = "update [用户表$] set 用户名='" + user.UserName + "',密码='" + user.Password + "' where 用户名='" + user.UserName + "'";
                int count = OledbHelper.ExecuteNonquery(sql);
                if (count == 1)
                {
                    MessageBox.Show("修改成功");
                    Thread thread = new Thread(DoWork);
                    thread.Start();
                }
            }
        }
        public delegate void MyInvoke();
        public void DoWork()
        {
            MyInvoke mi = new MyInvoke(LoadData);
            this.BeginInvoke(mi);
        }
帖子:http://topic.csdn.net/u/20120821/19/0300b744-df70-4119-8755-8ec3a6636585.html



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值