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

Diagrammes de Classes Discussion :

[DC]navigabilité entre les classes d'une association one-to-many


Sujet :

Diagrammes de Classes

  1. #1
    Membre régulier
    Inscrit en
    Mai 2006
    Messages
    330
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 330
    Points : 85
    Points
    85
    Par défaut [DC]navigabilité entre les classes d'une association one-to-many
    Salut,

    Je me pose le problème de définir correctement des objets qui peuvent avoir des relations bilatérales. Par exemple un objet "Page de livre" contient un ensemble d'objets "mot" mais réciproquement un objet "mot" peut se retrouver dans un ensemble d'objets "page de livre".

    Dans mon cas la performance est très importante, c'est à dire qu'il faut être capable de trouver le plus rapidement possible la liste des pages qui contient un mot et réciproquement la liste des mots contenus dans un page. Bref on veut optimiser la performance de recherche bidirectionnelle.

    Mon premier réflexe serait de définir dans l'objet "mot" une liste de "pages" et réciproquement dans l'objet "page" une liste de "mots". Cela répond correctement au problème de performance de la recherche bidirectionnelle mais j'ai l'impression que du point de vue conception objet c'est carrément nul. En effet il y a d'une part duplication d'information (mais c'est peut-être indispensable pour une recherche bidirectionnelle rapide) et d'autre part on introduit une dépendance peut-être trop forte entre les deux classes d'objets.

    Quelle solution élégante proposeriez-vous à ce problème ?

    Merci

  2. #2
    Membre confirmé Avatar de elbj
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Novembre 2004
    Messages
    371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Services à domicile

    Informations forums :
    Inscription : Novembre 2004
    Messages : 371
    Points : 558
    Points
    558
    Par défaut
    Bonjour

    Mon premier réflexe serait de définir dans l'objet "mot" une liste de "pages" et réciproquement dans l'objet "page" une liste de "mots". Cela répond correctement au problème de performance de la recherche bidirectionnelle mais j'ai l'impression que du point de vue conception objet c'est carrément nul. En effet il y a d'une part duplication d'information (mais c'est peut-être indispensable pour une recherche bidirectionnelle rapide) et d'autre part on introduit une dépendance peut-être trop forte entre les deux classes d'objets.
    Ca ne me semble pas une mauvaise méthode. J'aurai tendance à faire les choses ainsi. Après tout tu représentes simplement une relation n..m

    Cordialement
    Christophe B.

Discussions similaires

  1. les methodes et les associations entre les classes
    Par zin_rbt dans le forum Diagrammes de Classes
    Réponses: 1
    Dernier message: 24/05/2010, 14h41
  2. Réponses: 4
    Dernier message: 24/02/2009, 13h56
  3. [PHP5][MYSQL]Préserver une connexion entre les classes
    Par nesbla dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 02/02/2006, 11h51
  4. Question sur exports et les classes (pour une dll)
    Par DjPoke dans le forum Langage
    Réponses: 7
    Dernier message: 08/08/2005, 19h25
  5. [Reflection] Obtenir toutes les classes implémentant une interface
    Par Pill_S dans le forum API standards et tierces
    Réponses: 4
    Dernier message: 20/04/2005, 16h48

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