集合已修改;可能无法执行枚举操作

foreach  内部使用枚举器迭代,而这个迭代器在一开始的时候就返回了,它的迭代次数已经确定了, 如果后面更新了集合,导致之前的迭代次数不一致,就会出现上述错误。

当使用  foreach   的时候,集合只能处于只读状态,否则产生不可以预期的效果 

这个是使用foreach的典型的问题。foreach是取只读的,在取的时候数据不能变(包括修改,删除,添加等)。 
要避免这个问题,就应该使用for循环。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来解答你的问题。首先,这个错误是因为你在循环遍历 DataGridView 的列时,同时又在其中添加了按钮,并且在添加按钮时触发了 DataGridView 的事件,导致了集合修改的错误。解决这个问题的方法有两种: 1. 使用一个额外的 List 来存储所有的按钮,遍历完 DataGridView 的列后再将所有按钮添加到 DataGridView 中。 2. 在添加按钮时先解除 DataGridView 的事件绑定,添加完按钮后再重新绑定事件。 下面是第一种方法的示例代码,其中假设 DataGridView 的名称为 dgv: ``` Dim btnList As New List(Of Button) ' 用来存储所有的按钮 For i As Integer = 0 To dgv.Columns.Count - 1 ' 遍历所有的列 Dim btn As New Button btn.Text = "按钮" & i btn.Tag = i ' 设置按钮的 Tag 属性为列的索引,方便后面处理点击事件时获取对应的列 btnList.Add(btn) ' 将按钮添加到 List 中 Next For i As Integer = 0 To dgv.Rows.Count - 1 ' 遍历所有的行 For j As Integer = 0 To btnList.Count - 1 ' 遍历所有的按钮 dgv.Rows(i).Cells.Add(btnList(j).Clone()) ' 将按钮添加到单元格中 Next Next AddHandler dgv.CellClick, AddressOf dgv_CellClick ' 绑定 DataGridView 的点击事件 ' DataGridView 点击事件处理函数 Private Sub dgv_CellClick(sender As Object, e As DataGridViewCellEventArgs) If e.ColumnIndex >= 0 AndAlso TypeOf dgv.Columns(e.ColumnIndex) Is DataGridViewButtonColumn Then ' 判断是否点击了按钮列 Dim btn As Button = dgv.Rows(e.RowIndex).Cells(e.ColumnIndex).Value ' 获取点击的按钮 Dim colIndex As Integer = CInt(btn.Tag) ' 获取按钮对应的列索引 ' 处理点击事件 MessageBox.Show("点击了第 " & e.RowIndex + 1 & " 行第 " & colIndex + 1 & " 列的按钮") End If End Sub ``` 如果你想要使用第二种方法,可以将添加按钮的代码修改为: ``` Dim btn As New Button btn.Text = "按钮" & i btn.Tag = i AddHandler btn.Click, AddressOf btn_Click ' 绑定按钮的点击事件 dgv.Rows(i).Cells.Add(btn) RemoveHandler dgv.CellClick, AddressOf dgv_CellClick ' 解除 DataGridView 的点击事件绑定 AddHandler dgv.CellClick, AddressOf dgv_CellClick ' 重新绑定 DataGridView 的点击事件 ``` 其中,btn_Click 函数为按钮的点击事件处理函数,具体实现可以根据你的需求来编写。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值