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 :

Unhandled exception at (.) : Access violation writing location (.)


Sujet :

C

  1. #1
    Futur Membre du Club
    Inscrit en
    Mai 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 10
    Points : 7
    Points
    7
    Par défaut Unhandled exception at (.) : Access violation writing location (.)
    Bonjour,

    J'obtiens cette erreur de mémoire dans la partie suivante de mon programme :
    J'ai une matrice Q avec un nombre de ligne :Code->M (=252)*GF->M (=8) et un nombre de colonne : nbColumn (=5).
    J'ai une matrice H de taille Code->M (=252) par nbColumn (=5).
    J'ai une matrice Decoder->LR_INIT de taille GF->M (=8) par Code->N (=512).

    Je remplis la matrice Q avec les valeurs contenues dans LR_INIT. Mais comme elles ne sont pas de même taille au niveau des colonnes, LR_INIT ayant plus de colonnes, je séléctionne seulement certains éléments de LR_INIT. Le numéro de colonne de l'élément sélectionné est contenu dans la matrice qui contient les indices des colonnes à séléctionnner, c'est à dire H.

    J'obtiens l'erreur indiqué pour k=1, i=4, j=4, qui correspond à une valeur nulle dans H[k][j]. Le programme me dit alors qu'il ne peut évaluer Q[i+k*GF->M][j].

    Je n'arrive pas à trouver le problème. Si certains d'entre vous ont des idées ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
       for (k = 0; k < Code->M ; k++){ 
    	   for (i = 0 ; i < GF->M ; i++){
    		   for (j = 0 ; j < nbColumn ; j++) {
    			   if (Code->H[k][j]== 0){
    				   Q[i+k*GF->M][j] = 0;
    			   }
    			   else{
    				   Q[i+k*GF->M][j]= Decoder->LR_INIT[i][Code->H[k][j]];
    			   }
    		   }
    	   }
       }
    // correction de la taile de H, ne résoud pas l'erreur.

  2. #2
    Membre chevronné
    Profil pro
    Inscrit en
    Août 2006
    Messages
    1 104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 104
    Points : 1 750
    Points
    1 750
    Par défaut
    Code->M (=252)
    J'ai une matrice H de taille GF->M (=8) par nbColumn (=5).
    Dans ton code, tu écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for (k = 0; k < Code->M ; k++)
    (...)
    if (Code->H[k][j]== 0)
    Or, k va de 0 à Code->M-1, c'est-à-dire 251. Je pense que c'est ça qui provoque le crash.

  3. #3
    Futur Membre du Club
    Inscrit en
    Mai 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Après vérification, je me suis trompé dans les informations que j'ai donné :
    H est bien de taille Code->M(=252) par nbColumn(=5) et non ce que j'ai écrit au-dessus.
    H contient des entiers.
    Q et LR_INIT contienent des floats.

    Je vais continuer à chercher l'erreur.

  4. #4
    Futur Membre du Club
    Inscrit en
    Mai 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Voici l'allocation mémoire pour les différentes matrices.
    J'ai remarqué la chose suivante :
    lorsque les éléments de H sont des short et non des int, l'erreur que j'obtiens à lieu dès la 8ème ligne de Q
    lorsque les éléments de H sont des int, l'erreur que j'obtiens n'a lieu qu'à la 787 ligne de Q.
    Je me demande si je ne dépasse pas quelque part la taille des matrices. J'ai vérifié cela, mais je ne vois pas d'erreur. Il doit pourtant en avoir une.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
      /* Allocation pour H */
      Code->H = (int**) calloc(Code->M,sizeof(int*));
      if(Code->H == NULL){
    	  printf("Error in Allocation of H %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
      }
      Code->H[0] = (int*) calloc(Code->M*Code->maxLine ,sizeof(int));
       if(Code->H[0] == NULL){
    	  printf("Error in Allocation of H[0] %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
      }
    	for(i = 1; i < Code->M; i++)
    		Code->H[i] = Code->H[0] + i*Code->maxLine;
    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
     
    	/* Allocation pour LR_INIT */
     
      Decoder->LR_INIT = (float**) calloc( Code->N , sizeof(float*));
      if(Decoder->LR_INIT == NULL){
    	  printf("Error in Allocation of LR_INIT %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
      }
      Decoder->LR_INIT[0] = (float*) calloc( Code->N * GF->M , sizeof(float));
       if(Decoder->LR_INIT[0] == NULL){
    	  printf("Error in Allocation of LR_INIT[0] %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
      }
    	for(i = 1; i < Code->N ; i++)
    		Decoder->LR_INIT[i] = Decoder->LR_INIT[0] + i* GF->M;
    }
    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
     
    	nbLine = Code->M*GF->M;
    	nbColumn = Code->maxLine;
     
    	/* Allocation pour Q */
    	Q = (float**) calloc(nbLine,sizeof(float*));
      if(Q == NULL){
    	  printf("Error in Allocation of Q %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
      }
    	Q[0] = (float*) calloc(nbColumn,sizeof(float));
       if(Q[0] == NULL){
    	  printf("Error in Allocation of Q[0] %s:%d\n",__FILE__,__LINE__);
    	  exit(-1);
       }
       for(i = 1; i < nbLine ; i++){
    		Q[i] = Q[0] + i*nbColumn;
       }

  5. #5
    Expert éminent sénior
    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
    Points : 13 926
    Points
    13 926
    Par défaut
    Il y a trop peu dans l'allocation de Q

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    	Q[0] = (float*) calloc(nbColumn,sizeof(float));
    .....
       for(i = 1; i < nbLine ; i++){
    		Q[i] = Q[0] + i*nbColumn;
       }
    Les pointeurs Q[1], Q[2], .... pointent sur des zones non allouées
    N'est-ce pas plutôt
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Q[0] = calloc(nbColumn*nbLine,sizeof(float));
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  6. #6
    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
    Tu devrais regrouper ces allocations en fonction, pour être sûr de ne pas faire d'erreur.
    Tu peux t'inspirer de cela, en virant le "template", remplaçant T par float, et try/new/catch par calloc:
    http://www.developpez.net/forums/d74...e/#post4296674
    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
    Futur Membre du Club
    Inscrit en
    Mai 2009
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mai 2009
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Merci Diogène, c'est exactement ça !

    Entendu Medinoc, je vais tester ce que tu me conseilles, ça a l'air plutôt pratique.

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

Discussions similaires

  1. [OCILIB] OCI_LobRead erreur Access violation writing location
    Par capic dans le forum Interfaces de programmation
    Réponses: 3
    Dernier message: 05/12/2011, 08h52
  2. [débutant]Access violation reading location
    Par gate35 dans le forum C++
    Réponses: 6
    Dernier message: 13/05/2009, 14h32
  3. Réponses: 13
    Dernier message: 28/04/2008, 11h48
  4. Access violation writing location 0x00000010.
    Par dhoorens dans le forum C++
    Réponses: 6
    Dernier message: 29/12/2006, 11h23
  5. Réponses: 2
    Dernier message: 16/11/2006, 17h09

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