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

msdn的解释: foreach  语句是对枚举数的包装,它只允许从集合中读取,不允许写入集合。

也就是,不能在foreach里遍历的时侯把它的元素进行删除或增加的操作的

将注释的写法改为:

            //foreach (var tempOrderId in _OrderListForDataTime.Keys)
            //{
            //    if (_OrderListForDataTime[tempOrderId] > DateTime.Now.AddMinutes(-3))
            //    {
            //        GetAutoOutTicketTask tempGetAutoOutTicketTask = _OrderList[tempOrderId] as GetAutoOutTicketTask;
            //        tempGetAutoOutTicketTask.ExceptionEvent -= new ExceptionEventHandler(tempGetOrderTask_ExceptionEvent);
            //        AsyncTaskFactory.SysAsyncManager.DelAsyncClass(tempGetAutoOutTicketTask);
            //        _OrderList.Remove(tempOrderId);
            //        _OrderListForDataTime.Remove(tempOrderId);
            //    }
            //}
            ArrayList akeys = new ArrayList(_OrderListForDataTime.Keys);
            for (int i = 0; i < akeys.Count; i++)
            {
                long tempOrderId = (long)akeys[i];
                if (_OrderListForDataTime[tempOrderId] > DateTime.Now.AddMinutes(-3))
                {
                    GetAutoOutTicketTask tempGetAutoOutTicketTask = _OrderList[tempOrderId] as GetAutoOutTicketTask;
                    tempGetAutoOutTicketTask.ExceptionEvent -= new ExceptionEventHandler(tempGetOrderTask_ExceptionEvent);
                    AsyncTaskFactory.SysAsyncManager.DelAsyncClass(tempGetAutoOutTicketTask);
                    _OrderList.Remove(tempOrderId);
                    _OrderListForDataTime.Remove(tempOrderId);
                }
            }



  • 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、付费专栏及课程。

余额充值