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 :

utilisation d'une variable globale dans une librairie, quels sont les risques ?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    115
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 115
    Par défaut utilisation d'une variable globale dans une librairie, quels sont les risques ?
    Bonjour,

    Je me pose une question sur les risques pouvant découler de l'utilisation d'une variable globale dans une librairie.

    J'écris une librairie pour faire du parsing. Je souhaiterai que les modules qui vont utiliser cette librairie aient le moins de chose à gérer possible.

    Par exemple, j'ai une structure de configuration contenant les délimiteurs de liste, de fin de ligne, etc. Je n'ai pas envie que le module utilisant la lib doive s'allouer la structure et la passer à chaque appel à la librairie.

    J'ai donc pensé à déclarer la structure en globale dans la librairie, de cette manière plus besoin de s'en occuper puisqu'elle sera gérée dans la lib. Je me pose tout de même des questions sur les risques potentiels, je pense à des accès multiples à la librairies.

    Je ne pense pas que cela puisse poser des problèmes si ces accès se font depuis des processus différents, peut être que je me trompe. Mais si ce sont des threads d'un même processus qui veulent parser un fichier avec des configurations différentes ?

    Par avance merci

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Tu ne t'es pas trompé dans ton évaluation des risques. Par contre, je reviendrais là-dessus:
    Je n'ai pas envie que le module utilisant la lib doive s'allouer la structure et la passer à chaque appel à la librairie.
    Le module "utilisateur" n'a pas à allouer la structure, c'est à la lib de le faire (et de retourner un pointeur, de préférence un pointeur opaque).

    Ainsi, tout ce qu'il y a à trimbaler dans le code utilisateur, c'est le pointeur en question.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    115
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 115
    Par défaut
    Oui effectivement, l'utilisateur peut se passer de l'allocation.

    J'ai raison dans le cas de threads ou simplement des processus ? Si en multi processus cela peut fonctionner, ça ne me gêne pas. Peu de change que la lib soit utilisée avec des threads dans un même process, au pire je peux poser un mutex.

    Je ne sais pas quelle est la solution la plus propre, personnellement ça me gêne de traîner ce pointeur, l'utilisateur ne sait pas vraiment à quoi il sert, ce qu'il se passe avec.

  4. #4
    Membre Expert
    Profil pro
    Développeur en systèmes embarqués retraité
    Inscrit en
    Mars 2006
    Messages
    952
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2006
    Messages : 952
    Par défaut
    Salut
    Citation Envoyé par Odulo Voir le message
    Je ne sais pas quelle est la solution la plus propre, personnellement ça me gêne de traîner ce pointeur, l'utilisateur ne sait pas vraiment à quoi il sert, ce qu'il se passe avec.
    Quand tu ouvres un fichier avec fopen, la fonction te retourne un pointeur vers une structure de type FILE. Ca ne gène absolument personne de recevoir ce pointeur sans savoir ce qu'il y a dedans. Ca permet aussi aussi d'ouvrir plusieurs fichiers à la fois et de s'y retrouver malgré tout, même avec les threads.

    A+

    Pfeuh

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    115
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 115
    Par défaut
    Oui effectivement pfeuh, je vais donc procéder ainsi avec un void * comme le suggère Médinoc.

    Merci à vous

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Je n'ai jamais dit void*, j'ai dit pointeur opaque, ça n'est pas la même chose.

    Un pointeur opaque, c'est un pointeur vers une structure qui est déclarée mais pas définie (en clair, sa définition se trouve dans les fichiers d'en-tête internes à ta bibliothèque, mais pas dans celui que tu livres avec).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    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 Odulo Voir le message
    Je me pose une question sur les risques pouvant découler de l'utilisation d'une variable globale dans une librairie.

    J'écris une librairie pour faire du parsing. Je souhaiterai que les modules qui vont utiliser cette librairie aient le moins de chose à gérer possible.

    Par exemple, j'ai une structure de configuration contenant les délimiteurs de liste, de fin de ligne, etc. Je n'ai pas envie que le module utilisant la lib doive s'allouer la structure et la passer à chaque appel à la librairie.

    J'ai donc pensé à déclarer la structure en globale dans la librairie, de cette manière plus besoin de s'en occuper puisqu'elle sera gérée dans la lib. Je me pose tout de même des questions sur les risques potentiels, je pense à des accès multiples à la librairies.

    Je ne pense pas que cela puisse poser des problèmes si ces accès se font depuis des processus différents, peut être que je me trompe.
    Le fait qu'il y a ait des globales signifie que le code ne peut être instancié. C'est dommage, mais si ce n'est pas génant, c'est toi qui voit.

    Si ces variables globales sont à lecture seules (sauf config au démarrage), c'est sans risque pour la suite, si ce n'est que la configuration est unique.
    Mais si ce sont des threads d'un même processus qui veulent parser un fichier avec des configurations différentes ?
    Ca, par contre, c'est un vrai problème. La configuration est unique pour un processus donné (et tous les threads qui vont avec).

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

Discussions similaires

  1. Assignation d'une variable globale dans une fonction .
    Par moithibault dans le forum Général Python
    Réponses: 11
    Dernier message: 27/12/2010, 10h54
  2. une variable globale dans une page ASP
    Par zoro007 dans le forum ASP
    Réponses: 1
    Dernier message: 04/09/2010, 10h21
  3. [rendre une variable globale dans une fonction]
    Par emilek dans le forum ActionScript 3
    Réponses: 1
    Dernier message: 28/07/2009, 18h11
  4. Réponses: 6
    Dernier message: 21/07/2009, 11h37
  5. Réponses: 11
    Dernier message: 08/02/2006, 16h59

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