>백엔드 개발 >C++ >.NET 3.5에서 일반 OrderedDictionary를 구현하는 방법은 무엇입니까?

.NET 3.5에서 일반 OrderedDictionary를 구현하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-31 11:17:10244검색

How to Implement a Generic OrderedDictionary in .NET 3.5?

일반 OrderedDictionary 구현

OrderedDictionary의 일반 구현은 .NET 3.5에서 사용할 수 없지만 이를 만드는 것은 지나치게 복잡하지 않습니다. . 저장을 위해 KeyedCollection을 활용하고 List와 같은 항목을 정렬하는 다양한 방법을 구현할 수 있습니다. IList와 IDictionary의 하이브리드를 효과적으로 생성합니다.

인터페이스

public interface IOrderedDictionary<TKey, TValue> : IDictionary<TKey, TValue>, IOrderedDictionary
{
    // ...
}

구현

public class OrderedDictionary<TKey, TValue> : IOrderedDictionary<TKey, TValue>
{
    private KeyedCollection2<TKey, KeyValuePair<TKey, TValue>> _keyedCollection;
    
    // ...
}

도우미 클래스

public class KeyedCollection2<TKey, TItem> : KeyedCollection<TKey, TItem>
{
    private Func<TItem, TKey> _getKeyForItemDelegate;

    // ...
}

public class Comparer2<T> : Comparer<T>
{
    private readonly Comparison<T> _compareFunction;

    // ...
}

public class DictionaryEnumerator<TKey, TValue> : IDictionaryEnumerator, IDisposable
{
    // ...
}

테스트

[TestClass]
public class OrderedDictionaryTests
{
    // ...
}

이 테스트는 구현된 OrderedDictionary의 다양한 기능을 보여줍니다.

결론

.NET은 일반적인 OrderedDictionary 구현을 제공하지 않으므로 이러한 리소스를 사용하여 직접 구현하는 것은 키 기반 조회 속도와 삽입 순서를 모두 유지하기 위한 실행 가능한 솔루션입니다.

위 내용은 .NET 3.5에서 일반 OrderedDictionary를 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.