如何用BeginInvoke方法解决SetCurrentCellAddressCore 异常


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

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

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

posted on 2012-08-21 20:02  墨点  阅读(2346)  评论(0编辑  收藏  举报

导航