模仿TreeView结构的树结构类

using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Collections;
namespace  DocM
{
    
public class MyList
    
{
        
private List<DictionaryEntry> items = new List<DictionaryEntry>();
        
private int itemsInUse = 0;
        
/// <summary>
        
/// 构造函数
        
/// </summary>

        public MyList()
        
{
        }

        
/// <summary>
        
/// 构造函数
        
/// </summary>
        
/// <param name="Capacity">设置MyList容量</param>

        public MyList(int Capacity)
        
{
            
if (items.Count > Capacity)
                
throw new InvalidOperationException("设置MyList的容量不能小于原来的容量");
           
// else
            items.Capacity = Capacity;
        }

              

        
public void Add(string key, object value)
        
{
            items.Add(
new DictionaryEntry((object)key, value));
            itemsInUse
++;
        }

        
public object this[string key]
        
{
            
get
            
{
                
int index;
                
if (TryGetIndexOfKey(key, out index))
                    
return items[index].Value;
                
else
                    
return null;
            }

            
set
            
{
                
int index;
                
if (TryGetIndexOfKey(key, out index))
                
{
                    items.RemoveAt(index);
                    items.Insert(index, 
new DictionaryEntry(key, value));

                }

                
else
                    Add(key, value);
            }


        }

        
public object this[int index]
        
{
            
get
            
{
                
if ((index >= items.Count) || (index < 0))
                    
throw new OverflowException("数组越界");
                
return items[index].Value;
            }

            
set
            
{
                
if ((index >= items.Count) || (index < 0))
                    
throw new OverflowException("数组越界");
                DictionaryEntry de 
= items[index];
                items.RemoveAt(index);
                
string key = (string)de.Key;
                items.Insert(index, 
new DictionaryEntry(key, value));
            }

        }

        
private bool TryGetIndexOfKey(string key, out int index)
        
{
            
for (index = 0; index < itemsInUse; index++)
            
{
                
if (items[index].Key.Equals(key))
                    
return true;
            }

            
return false;
        }

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值