如何用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 }
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 }
教育改变生活,技术成就未来