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 :

Parcours de ICollection sur 2 niveaux


Sujet :

C#

  1. #1
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Orne (Basse Normandie)

    Informations professionnelles :
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 118
    Points : 100
    Points
    100
    Par défaut Parcours de ICollection sur 2 niveaux
    Bonjour,

    j'ai une collection de la forme ICollection<ExternalData> encapsulé dans une classe afin de masquer cette dernière.
    Cette classe renvoie un Enumerator de la forme IEnumerator<ExternalData>

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    void Funct()
    {
      var listEnumerator = collection.GetEnumerator(); // Get enumerator
     
      for (var i = 0; listEnumerator.MoveNext() == true; i++)
      {
        // Check 
        CheckItem (listEnumerator, listEnumerator.Current);
      }
    }
     
    void CheckItem(IEnumerator iter, object data)
    {
      // Loop from current position until the end
    }
    L'objectif est de parcourir la collection et voir si dans le reste de la liste un élément serait proche (je vais comparer différentes Propriétés de la classe ExternalData).
    J'ai donc 2 boucles d'imbriquées :
    - La première dans Funct() qui scanne tous les éléments
    - La deuxième dans CheckItem() qui scanne dans la même collection à partir de l'élément courant de Funct() et va jusqu'à la fin.

    On ne peut pas cloner IEnumerator

    La volumétrie des données est assez importante (10 millions d'entrées) donc il n'est pas concevable de convertir les données passées en entrée ou de réallouer de la RAM à la barbare.
    Quelqu'un aurait une idée pour un truc qui fonce ?

    Merci.
    Vincent

  2. #2
    Membre régulier
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    118
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Orne (Basse Normandie)

    Informations professionnelles :
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Novembre 2006
    Messages : 118
    Points : 100
    Points
    100
    Par défaut
    bon, j'ai fait un petit benchmark à coup de Stopwatch() sur 1 seul niveau pour voir la différence entre
    - Iterator avec MoveNext() : 767 ms
    - Accesseur [] : 810 ms

    Je me demande pourquoi je me fais ch... C'est plus long à charger les datas.

Discussions similaires

  1. [SQL] Affichage sur plusieurs niveaux
    Par oim dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 10/12/2007, 14h52
  2. [MySQL] réaliser une liste déroulante sur 3 niveaux provenant de 3 tables jointes mysql
    Par cel.Saint-Louis dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 06/11/2007, 15h22
  3. aide sur les niveaux de competences
    Par kmhermann1 dans le forum SAP
    Réponses: 1
    Dernier message: 10/09/2007, 23h16
  4. [Formulaire]filtre sur 4 niveaux de sous-formulaires
    Par fpecastaing dans le forum IHM
    Réponses: 48
    Dernier message: 12/04/2007, 12h43
  5. [Hibernate] Héritage sur plusieurs niveaux
    Par srvremi dans le forum Hibernate
    Réponses: 2
    Dernier message: 31/05/2006, 18h39

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