IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

ListDictionnary et getrange


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Par défaut ListDictionnary et getrange
    Bonjour à tous,

    j'utilise un ListDictionnary<string,MonObject> dans mon application car j'ai besoin d'un acces rapide a MonObject via la clé en string.

    Par contre, j ai besoin aussi par moment de réaliser un getrange pour obtenir les x derniers elements que j'ai ajoute à mon ListDictionnary.Et la ca coince, car je me vois mal enumerer tout mon dictionnaire pour obtenir les trois dernieres et ensuite les ressortir.

    Auriez vous quelques tours de magicien dans vos sacs pour réaliser ce getRange?

    Merci d'avance en tout cas,

  2. #2
    Membre Expert Avatar de Guulh
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    2 160
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2007
    Messages : 2 160
    Par défaut
    Ton besoin est un poil complexe, puisque tu as deux clés : une chaîne et un ordre d'insertion.

    La ListDictionnary implémente certes IDictionary (c'est un conteneur assocatif), mais sa structure sous-jacente ne l'est pas (d'où "List" dans son nom). Les recherches sont en O(n).

    Tu peux donc faire une List<KeyValuePair<string, object>>, avec les mêmes perfs, avec une méthode d'accès facile aux clés du style :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    class SuperList : List<KeyValuePair<string, object>>
    {
      public object FindByKey(string key)
      {
        // y'aurait une syntaxe plus compactre en C# 3
        return this.Find(delegate(KeyValuePair<string, object> kvp) {return kvp.Key == key; }); 
      }
      public IEnumerable<object> GetRange(int x)
      {
        for(int i = Min(0, this.Count - x) ; i < this.Count ; i++)
          yield return this[i].Value;
      }
    }

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo