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 :

Fonction générique de manipulation de structure (TAD)


Sujet :

C

  1. #1
    Membre émérite Avatar de Ceylo
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 216
    Par défaut Fonction générique de manipulation de structure (TAD)
    Bonjour,

    Je travaille sur un projet personnel de bibliothèque en C orienté objet (TAD).
    J'aimerais implémenter un mécanisme de comptage de référence. Pour ça, tous mes TAD doivent contenir un compteur, et une fonction doit pouvoir utiliser ce compteur de façon générique, c'est-à-dire que j'aimerais éviter de redéfinir les fonctions de manipulation de ce compteur pour chaque TAD.


    J'aimerais pouvoir faire la chose suivante :
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    struct MonTAD {
        struct gestionReferences;
        /* ... autres membres */
    };
     
    struct AutreTAD {
        struct gestionReferences;
        /* autres "autres membres" */
    };
     
    void Incrementer(void *tad)
    {
        struct gestionReferences * gestionnaire = (struct gestionReferences *)tad;
        gestionnaire->compteur++;
    }
     
    void Decrementer(void *tad)
    {
        struct gestionReferences * gestionnaire = (struct gestionReferences *)tad;
        gestionnaire->compteur--;
     
        if (gestionnaire->compteur == 0)
            gestionnaire->DestructeurAffecteParLeContructeurDuTAD();
    }

    La logique me dit que c'est possible, mais j'aimerais m'assurer qu'il n'y a pas de problèmes de décalage d'adresse entre l'adresse du TAD et l'adresse de son premier membre, ou si au pire je devrais passer par une structure de ce genre :
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    struct TADGenerique {
        struct gestionReferences;
    };

    Merci,
    Spootnik

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Spootnik Voir le message
    La logique me dit que c'est possible, mais j'aimerais m'assurer qu'il n'y a pas de problèmes de décalage d'adresse entre l'adresse du TAD et l'adresse de son premier membre, ou si au pire je devrais passer par une structure de ce genre :
    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    struct TADGenerique {
        struct gestionReferences;
    };
    Pour les données génériques, je recommande un void * sur les données (dynamiques, en général) de l'application. C'est le plus simple. Les données sont entièrement gérées par l'application. Le TAD n'enregistre que l'adresse et s'occupe du comportement (logique, algorithme).

    http://emmanuel-delahaye.developpez.com/tad.htm

  3. #3
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Un code structuré comme cela devrait en principe fonctionner:

    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
    16
    17
    18
    19
    20
    struct gestionReferences {
        size_t compteur;
        /* eventuellement d'autres membres */
    };
     
    struct MonTAD {
        struct gestionReferences gestionnaire;
        /* ... autres membres */
    };
     
    struct AutreTAD {
        struct gestionReferences gestionnaire;
        /* autres "autres membres" */
    };
     
    void Incrementer(void *tad)
    {
        struct gestionReferences * gestionnaire = (struct gestionReferences *)tad;
        gestionnaire->compteur++;
    }
    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  4. #4
    Membre émérite Avatar de Ceylo
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 216
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Pour les données génériques, je recommande un void * sur les données (dynamiques, en général) de l'application. C'est le plus simple. Les données sont entièrement gérées par l'application. Le TAD n'enregistre que l'adresse et s'occupe du comportement (logique, algorithme).

    http://emmanuel-delahaye.developpez.com/tad.htm
    Mon problème est surtout d'être certain que l'adresse du premier objet d'une structure est la même que l'adresse de la structure.


    Citation Envoyé par Thierry Chappuis
    Un code structuré comme cela devrait en principe fonctionner:
    C'est bien le "en principe" qui me chagrine .

  5. #5
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Spootnik Voir le message
    Mon problème est surtout d'être certain que l'adresse du premier objet d'une structure est la même que l'adresse de la structure.
    C'est garanti par le langage, mais je ne vois pas trop à quoi ça peut te servir...

  6. #6
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    La norme n1256 précise bien :

    6.7.2.1 Structure and union specifiers
    ....

    13 Within a structure object, the non-bit-field members and the units in which bit-fields reside have addresses that increase in the order in which they are declared. A pointer to a structure object, suitably converted, points to its initial member (or if that member is a bit-field, then to the unit in which it resides), and vice versa. There may be unnamed padding within a structure object, but not at its beginning.

  7. #7
    Membre émérite Avatar de Ceylo
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 216
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    C'est garanti par le langage, mais je ne vois pas trop à quoi ça peut te servir...
    À être sûr que si je "cast" mon TAD (ayant en premier membre un pointeur sur la structure de gestion des références) en TAD générique (ayant pour seul membre un pointeur sur la structure de gestion des références), j'aurai un accès garanti à mes informations.

    Citation Envoyé par diogene Voir le message
    La norme n1256 précise bien : [...]
    Merciii ! C'est exactement ça dont je voulais être sûr .

  8. #8
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Spootnik Voir le message
    À être sûr que si je "cast" mon TAD (ayant en premier membre un pointeur sur la structure de gestion des références) en TAD générique (ayant pour seul membre un pointeur sur la structure de gestion des références), j'aurai un accès garanti à mes informations.
    J'ai du mal à voir pourquoi tu as besoins de ça. Ici, il s'agit de manipuler des données. On n'a rien à faire du fait qu'elles soient consécutives. Un pointeur void * sur un bloc suffit pour être générique. J'ai commis la même erreur il y a longtemps :

    http://emmanuel-delahaye.developpez.com/clib.htm
    Module Q

    erreur que j'ai corrigée par la suite :

    Module GFIFO.
    Module GLL.
    Module FARR.
    Module FSTR.

  9. #9
    Membre émérite Avatar de Ceylo
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2007
    Messages
    1 216
    Détails du profil
    Informations personnelles :
    Âge : 34
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 216
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    J'ai du mal à voir pourquoi tu as besoins de ça.
    Parce que le gestionnaire de références ne connaît pas le contenu des structures définissant mes TADs. La seule règle qu'il suppose est que le premier membre du TAD est un pointeur vers la structure de gestion des références.

  10. #10
    Membre très actif

    Profil pro
    Étudiant
    Inscrit en
    Décembre 2004
    Messages
    499
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2004
    Messages : 499
    Par défaut
    salut

    historiquement, le C++ était un espèce de gros préprocesseur qui convertissait le code en C,
    et l'héritage était logiquement implémenté comme ça

    c'est exactement ce que tu fais ici, simuler l'héritage de données membre

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. fonction générique pour get set et change
    Par tretsois dans le forum C++
    Réponses: 9
    Dernier message: 18/02/2007, 18h28
  2. [VB.Net] fonctions génériques pour le new
    Par ohcysp dans le forum Windows Forms
    Réponses: 3
    Dernier message: 11/09/2006, 11h47
  3. Aide sur une fonction / pbm de manipulation de caractère
    Par captainamerica75 dans le forum Access
    Réponses: 3
    Dernier message: 16/02/2006, 11h54
  4. Fonctions génériques et listes
    Par DevloNewb' dans le forum C++
    Réponses: 6
    Dernier message: 13/01/2006, 14h47
  5. fonction c pour manipuler la structure date
    Par thomas_b dans le forum Windows
    Réponses: 4
    Dernier message: 28/07/2004, 16h28

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