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 :

Comportement différent selon Mode Execution


Sujet :

C

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2006
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Chine

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2006
    Messages : 71
    Points : 52
    Points
    52
    Par défaut Comportement différent selon Mode Execution
    Bonjour,

    Je travaille actuellement à débugger un programme dont le comportement est différent selon que je suis en exécution normale ou en mode debug ! (avec gdb)

    En comportement normal, le comportement n'est pas bon. Le programme oublie à un moment d'écrire dans un fifo.
    En mode debug, le programme se déroule correctement, il écrit tous ses messages. Il écrit même chaque message en double...

    D'où peuvent venir en général ces différences de comportement selon le mode d'exécution ? Je suis sans ressource puisque quand je travaille avec le débugger tout se passe bien...

    Merci d'avance pour votre aide.

  2. #2
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    D'expérience, ce genre de problème sent le pointeur ou la variable mal/pas initialisé.

    dans ce cas, printf() et ses équivalents est ton ami

    Courage !!
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  3. #3
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    souvent c'est effectivement un pointeur pas initialisé ou un débordement
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Qu'appelles-tu comportement normal ?
    Mode Release ? Ou mode Debug lancé hors du debugger ?
    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.

  5. #5
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2006
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Chine

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2006
    Messages : 71
    Points : 52
    Points
    52
    Par défaut
    Merci pour vos réponses aussi rapides!
    Je vais donc analyser le code d'encore un peu plus près..

    Sinon je me rends compte en relisant mon poste que je me suis un peu emmelé les pinceaux. Fatigue...

    En comportement normal, le comportement n'est pas bon.
    Je voulais dire en mode normal, le comportement n'est pas celui que j'attendais.
    Par mode normal, j'entends : quand je lance le programme à partir d'un shell, après l'avoir compilé avec gcc (option debug présente), en dehors de gdb donc.

    Sinon comment se fait-il qu'un débordement de mémoire ou un oubli d'initialisation a un effet en dehors du debogueur et n'en a pas sinon ..?
    Le débogueur s'occuperait-il d'initialiser les variables ? de faire des malloc ?

  6. #6
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Points : 50 367
    Points
    50 367
    Par défaut
    Effectivement, ce complément d'information est important.

    Si le comportement en "mode debug + shell" est différent du comportement en "mode debug + debugger", tu as un problème ailleurs.

    Normallement, le debugger n'a pas d'effet de bord sur les initialisations de variables et sur les allocations mémoire. Le seul effet de bord que je voie concerne l'ordonnancement des threads à l'intérieur du process. Il peut être différent entre "mode debug + debugger" et "mode debug + shell"

    Je me permets d'insister, tu es sûr de lancer le même binaire dans le shell et dans le debugger ?
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  7. #7
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2006
    Messages
    71
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Chine

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2006
    Messages : 71
    Points : 52
    Points
    52
    Par défaut
    Oui, même binaire.

    J'ai lu et relu le code, fais des prints, je suis pratiquement sûr que tout est initialisé.
    Je regarderai encore demain à tête reposée.

    Bon par contre je me suis rendu compte que la différence de comportement est entre le mode step by step avec le débogueur et les autres modes (à partir du shell ou débogueur en mode run).

    Aha ! Le fait d'écrire ce message m'a donné envie d'essayer un sleep, et du coup ça marche... mieux

    Merci pour votre aide! J'ai plus qu'à comprendre pourquoi le fait d'aller trop vite fait manquer un épisode au programme.. Je flaire l'histoire de lecture/écriture de fichier..

    Bonne continuation

  8. #8
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 307
    Points
    5 307
    Par défaut
    Tu peux aussi faire un flush après chaque écriture ...
    Vincent Rogier.

    Rubrique ORACLE : Accueil - Forum - Tutoriels - FAQ - Livres - Blog

    Vous voulez contribuer à la rubrique Oracle ? Contactez la rubrique !

    OCILIB (C Driver for Oracle)

    Librairie C Open Source multi-plateformes pour accéder et manipuler des bases de données Oracle

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 07/05/2012, 18h13
  2. Comportement différent selon le contexte
    Par Invité dans le forum Linq
    Réponses: 5
    Dernier message: 24/10/2011, 08h18
  3. SimUnlockPhone comportement différent selon les téléphones
    Par bobby51 dans le forum Windows Mobile
    Réponses: 0
    Dernier message: 29/04/2011, 10h43
  4. Réponses: 7
    Dernier message: 15/02/2010, 21h52
  5. Comportement différent selon le lanceur
    Par michelcky dans le forum GTK+ avec C & C++
    Réponses: 1
    Dernier message: 03/10/2008, 19h03

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