zoukankan      html  css  js  c++  java
  • wp7 BaseDictionary<TKey, TValue>

    /// <summary>
    ///
     Represents a dictionary mapping keys to values.
    /// </summary>
    ///
     
    /// <remarks>
    ///
     Provides the plumbing for the portions of IDictionary<TKey,
    /// TValue>
     which can reasonably be implemented without any
    /// dependency on the underlying representation of the dictionary.
    /// </remarks>
    [DebuggerDisplay("Count = {Count}")]
    [
    DebuggerTypeProxy(PREFIX + "DictionaryDebugView`2" + SUFFIX)]
    public abstract class BaseDictionary<TKey, TValue> : IDictionary<TKey, TValue> {
        
    private const string PREFIX = "System.Collections.Generic.Mscorlib_";
        
    private const string SUFFIX =",mscorlib,Version=2.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089";

        
    private KeyCollection keys;
        
    private ValueCollection values;

        
    protected BaseDictionary() { }

        
    public abstract int Count { get; }
        
    public abstract void Clear();
        
    public abstract void Add(TKey key, TValue value);
        
    public abstract bool ContainsKey(TKey key);
        
    public abstract bool Remove(TKey key);
        
    public abstract bool TryGetValue(TKey key, out TValue value);
        
    public abstract IEnumerator<KeyValuePair<TKey, TValue>> GetEnumerator();
        
    protected abstract void SetValue(TKey key, TValue value);

        
    public bool IsReadOnly {
            
    get { return false; }
        }

        
    public ICollection<TKey> Keys {
            
    get {
                
    if (this.keys == null)
                    
    this.keys = new KeyCollection(this);

                
    return this.keys;
            }
        }

        
    public ICollection<TValue> Values {
            
    get {
                
    if (this.values == null)
                    
    this.values = new ValueCollection(this);

                
    return this.values;
            }
        }

        
    public TValue this[TKey key] {
            
    get {
                TValue value;
                
    if (!this.TryGetValue(key, out value))
                    
    throw new KeyNotFoundException();

                
    return value;
            }
            
    set {
                SetValue(key, 
    value);
            }
        }

        
    public void Add(KeyValuePair<TKey, TValue> item) {
            
    this.Add(item.Key, item.Value);
        }

        
    public bool Contains(KeyValuePair<TKey, TValue> item) {
            TValue value;
            
    if (!this.TryGetValue(item.Key, out value))
                
    return false;

            
    return EqualityComparer<TValue>.Default.Equals(value, item.Value);
        }

        
    public void CopyTo(KeyValuePair<TKey, TValue>[] array, int arrayIndex) {
            Copy(
    this, array, arrayIndex);
        }

        
    public bool Remove(KeyValuePair<TKey, TValue> item) {
            
    if (!this.Contains(item))
                
    return false;

            return this.Remove(item.Key);
        }

        System.Collections.
    IEnumerator System.Collections.IEnumerable.GetEnumerator() {
            
    return this.GetEnumerator();
        }

        
    private abstract class Collection<T> : ICollection<T> {
            
    protected readonly IDictionary<TKey, TValue> dictionary;

            
    protected Collection(IDictionary<TKey, TValue> dictionary) {
                
    this.dictionary = dictionary;
            }

            
    public int Count {
                
    get { return this.dictionary.Count; }
            }

            
    public bool IsReadOnly {
                
    get { return true; }
            }

            
    public void CopyTo(T[] array, int arrayIndex) {
                Copy(
    this, array, arrayIndex);
            }

            
    public virtual bool Contains(T item) {
                
    foreach (T element in this)
                    
    if (EqualityComparer<T>.Default.Equals(element, item))
                        
    return true;
                
    return false;
            }

            
    public IEnumerator<T> GetEnumerator() {
                
    foreach (KeyValuePair<TKey, TValue> pair in this.dictionary)
                    
    yield return GetItem(pair);
            }

            
    protected abstract T GetItem(KeyValuePair<TKey, TValue> pair);

            
    public bool Remove(T item) {
                
    throw new NotSupportedException("Collection is read-only.");
            }

            
    public void Add(T item) {
                
    throw new NotSupportedException("Collection is read-only.");
            }

            
    public void Clear() {
                
    throw new NotSupportedException("Collection is read-only.");
            }

            System.Collections.
    IEnumerator System.Collections.IEnumerable.GetEnumerator() {
                
    return this.GetEnumerator();
            }
        }

        [
    DebuggerDisplay("Count = {Count}")]
        [
    DebuggerTypeProxy(PREFIX + "DictionaryKeyCollectionDebugView`2" + SUFFIX)]
        
    private class KeyCollection : Collection<TKey> {
            
    public KeyCollection(IDictionary<TKey, TValue> dictionary)
                : 
    base(dictionary) { }

            
    protected override TKey GetItem(KeyValuePair<TKey, TValue> pair) {
                
    return pair.Key;
            }
            
    public override bool Contains(TKey item) {
                
    return this.dictionary.ContainsKey(item);
            }
        }

        [
    DebuggerDisplay("Count = {Count}")]
        [
    DebuggerTypeProxy(PREFIX + "DictionaryValueCollectionDebugView`2" + SUFFIX)]
        
    private class ValueCollection : Collection<TValue> {
            
    public ValueCollection(IDictionary<TKey, TValue> dictionary)
                : 
    base(dictionary) { }

            
    protected override TValue GetItem(KeyValuePair<TKey, TValue> pair) {
                
    return pair.Value;
            }
        }

        
    private static void Copy<T>(ICollection<T> source, T[] array, int arrayIndex) {
            
    if (array == null)
                
    throw new ArgumentNullException("array");

            
    if (arrayIndex < 0 || arrayIndex > array.Length)
                
    throw new ArgumentOutOfRangeException("arrayIndex");

            
    if ((array.Length - arrayIndex) < source.Count)
                
    throw new ArgumentException("Destination array is not large enough. Check array.Length and arrayIndex.");

            
    foreach (T item in source)
                array[arrayIndex++] = item;
        }
    }
  • 相关阅读:
    适配器模式
    自己DIY word2010脚注和尾注没有的格式
    Linux单网卡,双IP,双网关配置,并搭建squid proxy上网
    about using gnuplot
    ReadDirectoryChangesW 函数 流沙
    Jquery easyui 异步树 流沙
    Overlapped I/O 学习 流沙
    jQuery.get(url,[data],[callback]) 流沙
    MsgWaitForMultipleObjectsEx用法 流沙
    Oracle smon_scn_time 表 说明
  • 原文地址:https://www.cnblogs.com/luquanmingren/p/3156126.html
Copyright © 2011-2022 走看看