• 递归DeleteMenuItem


    /// <summary>
            /// 删除节点
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            void DeleteMenuItem(object sender, EventArgs e)
            {
                MenuTreeNode curNode = menuTreeView.SelectedNode as MenuTreeNode;
                if (curNode.Nodes.Count > 0)
                    DeleteNodes(curNode);
                else
                {
                    curNode.Record.Delete();
                    curNode.Remove();
                }
    
            }
            /// <summary>
            /// 递归删除节点,特别说明:递归删除节点不能用foreach和for,因为节点删除后,下次迭代目标是null,不过递减方式遍历也许可以
            /// </summary>
            /// <param name="node">待删除的节点</param>
            void DeleteNodes(MenuTreeNode node)
            {
                MenuTreeNode tmpNode = node;
                
                while (tmpNode != null)
                {
                    if (tmpNode.Nodes.Count > 0)
                    {
                        DeleteNodes((MenuTreeNode)tmpNode.Nodes[0]);
                    }
                    MenuTreeNode aNode = tmpNode;
                    tmpNode = (MenuTreeNode)tmpNode.NextNode;
                    aNode.Record.Delete();
                    aNode.Remove();
                 
                }
               
  • 相关阅读:
    最短路总结
    关于最小生成树(并查集)prime和kruskal
    关于优先队列浅析(priority_queue)
    惨痛第十届蓝桥杯总结(附录蓝桥省赛知识点总结)-C++ B组
    初识STL vector
    sort();对结构体数组的排序
    Git 分支管理
    Git 远程仓库
    Matlab R2016a 破解教程
    Ubuntu卡在logo界面
  • 原文地址:https://www.cnblogs.com/perock/p/3074442.html
Copyright © 2020-2023  润新知