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 :

Lecture de la mémoire à l'adresse 0x000000 à la fermeture


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    13
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 13
    Par défaut Lecture de la mémoire à l'adresse 0x000000 à la fermeture
    Bonjour à tous,

    Je travaille actuellement sur un projet en WinAPI qui fonctionne bien, jusqu'au moment où l'on tente de fermer le programme. Alors, on obtient l'erreur suivante: "La mémoire à l'adresse 0x00000000 ne peut pas être read".
    Si j'exécute le programme avec le débogueur, le problème ne se produit pas. Mais j'ai remarqué que 0x00000000 est l'adresse de retour située à la base de la pile d'appels.

    J'utilise NetBeans 6.7.1 avec MinGW.

    Merci d'avance pour votre aide.

  2. #2
    Membre Expert
    Avatar de Klaim
    Homme Profil pro
    Développeur de jeux vidéo
    Inscrit en
    Août 2004
    Messages
    1 717
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur de jeux vidéo
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 1 717
    Par défaut
    C'est la valeur "nulle" utilisée par les pointeurs aussi.

    A priori tu utilises un objet via un pointeur mais le pointeur est nul. Vérifie voir ce que tu manipules lorsque tu quittes ton programme. Si tu manipules des pointeurs a un endroit, fait une assertion vérifiant que les pointeurs sont nuls a chaque fois que tu en récupères un. Comme ça tu sauras rapidmenet où tu utilises un pointeur null.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    13
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 13
    Par défaut
    En utilisant le débogueur de VC++, j'ai réussi à localiser la partie du code où ça coince. Seulement, je ne comprends ce qui pose problème dedans.
    Voici le message d'erreur:
    Exception de première chance à 0x7c921129 dans Analharm.exe*: 0xC0000005: Violation d'accès lors de la lecture de l'emplacement 0x003b7005.
    Et voici le code en cause:
    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
    double** charger_courants (struct simulation* simul)
    {
        double** courants;
        int taille_tampon = 31 * simul->nb_pr + 15;
        char* tampon = NULL;
        char delimiteur[] = "\t";
        char* champs = NULL;
        int i, pas;
    
        courants = (double **) malloc((simul->nb_pr + 1)*sizeof(double));
        for (i=0; i<simul->nb_pr + 1; i++)
        {
            courants[i] = (double *) malloc((simul->duree + 1)*sizeof(double));
        }
        tampon = (char*) malloc(taille_tampon*sizeof(char));
    
        [...]
    }
    La ligne qui coince est celle en gras.

    Merci d'avance pour votre aide.

  4. #4
    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 : 62
    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
    Par défaut
    Quelle est la valeur du pointeur simul lorsque cela plante. (je parie pour un NULL)

    Il est possible de voir la pile d'appel, les paramètres ainsi que les variables locales en utilisant le debuger de VC au moment du crash.
    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
    .

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    13
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Septembre 2009
    Messages : 13
    Par défaut
    simul vaut 0x003b5c20 et simul->nb_pr vaut 1.

    Et voici le contenu de la pile d'appels:
    ntdll.dll!7c921129()
    [Les frames ci-dessous sont peut-être incorrects et/ou manquants, aucun symbole chargé pour ntdll.dll]
    uxtheme.dll!5b0ac406()
    uxtheme.dll!5b0ac3c8()
    uxtheme.dll!5b091adb()
    ntdll.dll!7c91cf7a()
    ntdll.dll!7c92a2a3()
    ntdll.dll!7c9218c0()
    msvcr90d.dll!102c103e()
    msvcr90d.dll!102cfd76()
    msvcr90d.dll!102cfb2f()
    msvcr90d.dll!102cfadc()
    msvcr90d.dll!102db25b()
    > Analharm.exe!charger_courants(simulation * simul=0x003b5c20) Ligne 27 + 0x16 octets C++
    Analharm.exe!exploiter_saisie_simulation(simulation * simul=0x003b5c20) Ligne 776 + 0x9 octets C++
    Analharm.exe!nouvelle_simulation(HWND__ * hWnd=0x001e084c, unsigned int uMsg=273, unsigned int wParam=40000, long lParam=0) Ligne 1174 + 0xc octets C++
    Analharm.exe!MainWndProc(HWND__ * hWnd=0x001e084c, unsigned int uMsg=273, unsigned int wParam=40000, long lParam=0) Ligne 1429 + 0x15 octets C++
    user32.dll!7e398734()
    user32.dll!7e398816()
    user32.dll!7e3989cd()
    user32.dll!7e398a10()
    Analharm.exe!WinMain(HINSTANCE__ * hinstance=0x00400000, HINSTANCE__ * hPrevInstance=0x00000000, char * lpCmdLine=0x00162359, int nCmdShow=1) Ligne 1481 + 0xc octets C++
    Analharm.exe!__tmainCRTStartup() Ligne 578 + 0x35 octets C
    Analharm.exe!WinMainCRTStartup() Ligne 403 C
    kernel32.dll!7c817077()

  6. #6
    screetch
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (simul->nb_pr + 1)*sizeof(double)
    devrait etre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (simul->nb_pr + 1)*sizeof(double*)
    ca marche quand meme car sizeof(double) >= sizeof(double*) mais n'empeche.

    tu appelles cette fonction plusieurs fois d'affilée ? ca plante a la combientieme fois ?

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

Discussions similaires

  1. Lecture Ecriture en mémoire
    Par DarkVader dans le forum VB 6 et antérieur
    Réponses: 0
    Dernier message: 17/07/2009, 19h14
  2. [Ifstream] Lecture fichier et mémoire
    Par michaeljeru dans le forum SL & STL
    Réponses: 4
    Dernier message: 28/01/2008, 21h57
  3. [LG]Lecture de fichier avec une adresse internet
    Par forbin dans le forum Langage
    Réponses: 8
    Dernier message: 09/02/2005, 19h00

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