Implémentation de OrderedDictionary
La mise en œuvre d'un OrderedDictionary générique n'est pas une tâche complexe, mais elle peut prendre du temps et est considérée comme un oubli sur Microsoft. partie. Il existe différentes méthodes pour l'implémenter, mais une approche consiste à utiliser une KeyedCollection pour le stockage interne et un hybride Key et List pour le tri de la même manière que List.
Structure de classe
L'interface du OrderedDictionary générique (IOrderedDictionary) comprend à la fois le générique et interfaces non génériques (System.Collections.Specialized.IOrderedDictionary). La classe d'implémentation (OrderedDictionary) hérite de la classe KeyedCollectionBase avec un champ privé de type KeyedCollection2> pour stocker les paires clé-valeur en interne.
Méthodes remplacées
La classe OrderedDictionary remplace diverses méthodes de IDictionary et IOrderedDictionary :
- Méthodes liées à la gestion clé-valeur (Add, Clear, ContainsKey, Remove)
- Propriétés de l'indexeur pour accéder aux valeurs par clé ou index (this[TKey key] , this[int index])
- Méthodes de manipulation de l'ordre des éléments (Insert, IndexOf, RemoveAt)
- Méthodes pour récupérer ou définir des paires clé-valeur par index (GetValue, SetValue, GetItem, SetItem)
- Implémentations d'énumérateur et de propriété pour itérer dans la collection (GetEnumerator, Count, Keys, Valeurs)
Tri Capacités
La classe OrderedDictionary comprend des méthodes pour trier les clés ou les valeurs de différentes manières, à l'aide de comparateurs intégrés ou personnalisés :
- SortKeys() : trie les clés selon leur valeur naturelle order.
- SortKeys(IComparer comparer) : trie les clés en utilisant le spécifié comparer.
- SortKeys(Comparison comparative) : trie les clés en utilisant le délégué de comparaison spécifié.
- SortValues() : trie les valeurs selon leur ordre naturel.
- SortValues( IComparer comparer) : trie les valeurs à l'aide du comparateur spécifié.
- SortValues(Comparison comparative) : trie les valeurs à l'aide du délégué de comparaison spécifié.
Fonctionnalités supplémentaires
La classe OrderedDictionary prend également en charge des fonctionnalités telles que as :
- Accès à la KeyedCollection interne via la propriété _keyedCollection.
- Algorithmes de tri hérités de la classe KeyedCollection2 (SortByKeys, Sort, SortByKeys).
- Méthodes d'assistance pour créer des DictionaryEnumerators à utiliser avec IOrderedDictionary.
Exemple d'utilisation
L'exemple de code fourni montre comment créer, manipuler et trier une instance OrderedDictionary :
- Création d'un OrderedDictionary avec des paires clé-valeur.
- Récupération et définition de valeurs à l'aide d'indexeurs et méthodes GetValue/SetValue.
- Utilisation des méthodes SortKeys et SortValues pour trier le dictionnaire par clés ou valeurs.
- Énumération à travers la collection pour accéder à chaque paire clé-valeur.
Conclusion
Bien que .NET ne le fasse pas fournissent nativement une implémentation générique de OrderedDictionary, l'exemple de code fourni offre une alternative robuste qui peut être adaptée à des besoins spécifiques. Cette implémentation comble le vide des bibliothèques de collections .NET, permettant une gestion efficace et organisée des données avec un accès basé sur des clés et des index.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!
Déclaration:Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn