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 :

[interfaçage C/Fortran] erreur de segmentation


Sujet :

C

  1. #1
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut [interfaçage C/Fortran] erreur de segmentation
    Bonjour à tous,
    J'ai hérité d'une librairie C écrite il y a des lustres et qui sert à allouer une plage mémoire.
    Cette librairie est apellée par un programme fortran qui passe la variable à allouer en paramètre.
    j'ai crée un petit programme de test qui reproduit le problème car malheureusement je ne vois pas ce qui cloche :/

    Le programme fortran:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    program testlib
     
           integer nelem,elsize,work,tbaddr,offset
           nelem=10
           elsize=1
           work=0
           tbaddr=0
           offset=0
     
           call falloc(nelem,elsize,work,tbaddr,offset)
     
           end program testlib
    La librairie C:

    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    #include <stdlib.h>
    #include <stdio.h>
     
    falloc_(nelem,elsize,basevec,addr,offset)
    int *nelem,*elsize,*basevec,*addr,*offset;
    {
       int noct;
       int adbase;
       int *ptr;
       int rest;
     
       if( *elsize > 8)
          noct=(*nelem + 1) * (*elsize); /* Nombre d'octets */
       else
          noct=(*nelem)*(*elsize); /* Nombre d'octets */
     
       if(noct<=0){
          *addr=0;
          printf("noct <  0 bizarre \n");
          return;
       }
     
       ptr=(int *) malloc(noct); /* Allocation */
       /*(int *)*addr=ptr; */
       *addr=(int)ptr;
       adbase=(int)basevec;
       *offset=(*addr-adbase)/(*elsize);
       rest=(*addr-adbase)-(*offset) * (*elsize);
       if(rest!=0) *offset=*offset+1;
    }
    Je compile avec sunstudio sans options particulières.
    Merci à celui/celle qui pourrais jeter un oeil et me dire pourquoi j'ai des valeurs de sortie incohérentes ^^

    par exemple: en entrée j'ai
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    nelem = 10
    elsize=1
    work=0
    tbaddr=0
    offset=0
    en sortie:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     nelem =  10
     elsize =  1
     work =  0
     tbaddr =  415111376
     offset =  408813608

  2. #2
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Je ne connais pas fortran donc mes remarques ne peuvent se porter que sur la fonction falloc_(). Au passage on remarquera que la fonction se nomme falloc_ alors que le code fortran appelle juste falloc. De plus la fonction est sensée recevoir des adresses mais le code Fortran passe des valeurs mais je présume que c'est l'usage quand on interface Fortran/C.

    Bon, ceci dit, voici ce qui me choque: déjà on ne caste plus un malloc depuis que celui-ci renvoie un void*. Au contraire, le cast d'un malloc peut en retour masquer un oubli #include. Mais je suis surtout étonné par cette ligne 25 *addr=(int)ptr;. ptr contient l'adresse allouée par malloc et tu vas copier cette adresse dans un int ??? Je ne sais pas comment on gère les adresse en Fortran mais ça ça me choque. De même cette copie de basevec (une adresse) dans adbase (un int)...

    Au passage, bien que je n'en comprenne pas la raison, on peut optimiser un peu ton bloc if/else de cette façon
    Code c : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    noct=(*nelem)*(*elsize); /* Nombre d'octets */
    if( *elsize > 8)
          noct+=(*elsize);

    Et la ligne 28 peut se raccourcir en rest=(*addr-adbase) % (*elsize); et la variable adbase ne sert à rien du tout vu que c'est le contenu de basevec

    Maintenant, peut-être qu'en rajoutant quelques printf() dans ta fonction tu pourras affiner l'instruction qui pose soucis...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut
    merci pour ton aide

    En mettant des printf dans le code, on se rend compte que les valeurs

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    tbaddr =  415111376
     offset =  408813608
    que j'obtiens en sortie (et qui normalement sont les valeurs des variables) correspondent (si je comprend bien) à la valeur des adresses converties en entier dans la librairie...

  4. #4
    Membre Expert
    Avatar de Metalman
    Homme Profil pro
    Enseignant-Chercheur
    Inscrit en
    Juin 2005
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enseignant-Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 049
    Par défaut
    Question bête : tu n'as aucune option pour débugger ou mettre le numéro de la ligne qui segfault ?
    Si tu as sunstudio, je suppose que tu es sur une station Sun (thx cpt. obvious ! pour moi... ), n'as-tu aucun port de gcc ou gdb dessus ? Ni l'option pour faire du pas à pas ? (si sunstudio possède une IDE, ce que j'espère !)
    --
    Metalman !

    Attendez 5 mins après mes posts... les EDIT vont vite avec moi...
    Les flags de la vie : gcc -W -Wall -Werror -ansi -pedantic mes_sources.c
    gcc -Wall -Wextra -Werror -std=c99 -pedantic mes_sources.c
    (ANSI retire quelques fonctions comme strdup...)
    L'outil de la vie : valgrind --show-reachable=yes --leak-check=full ./mon_programme
    Et s'assurer que la logique est bonne "aussi" !

    Ma page Developpez.net

  5. #5
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Ça fait bizarre, tous tes paramètres déclarés en int*, sans aucune notion de type (tbaddr devrait être au minimum void**) ou de constante (pour les paramètres que la fonction ne modifie pas).

    Et qu'est censé signifier basevec?
    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.

  6. #6
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut
    je suis sous Linux avec un debogueur (totalview) qui m'affiche les valeurs des variables au petit bonheur la chance (apparemment il aime pas du tout les pointeurs :/).

  7. #7
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Déjà, le même code avec un minimum de rigueur (et de modernité):
    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    #include <stdlib.h>
    #include <stdio.h>
     
    void falloc_impl(int nelem, int elsize, int basevec, void **pAddr, int *pOffset)
    {
       size_t noct;
       intptr_t adbase, adalloc;
       void *ptr;
       int rest;
     
     
       if( elsize > 8)
          noct = (nelem + 1) * elsize; /* Nombre d'octets */
       else
          noct = nelem*elsize; /* Nombre d'octets */
     
       if(noct<=0){
          *pAddr=NULL;
          printf("noct <  0 bizarre \n");
          return;
       }
     
       ptr = malloc(noct); /* Allocation */
       *pAddr = ptr;
       adbase = (intptr_t)basevec;
       adalloc = (intptr_t)ptr;
       *pOffset = (adalloc-adbase)/elsize;
       rest=(adalloc-adbase)-(*pOffset)*elsize;
       if(rest!=0) (*pOffset)++;
    }
     
    void falloc_(int *nelem, int *elsize, int *basevec, void **addr, int *offset)
    {
       falloc_impl(*nelem, *elsize, *basevec, addr, offset);
    }
    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.

  8. #8
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut
    Je me suis renseigné, il parait que le gars qui a écrit la librairie est mort

    Merci pour votre aide, je vais essayer de me débrouiller avec les infos que vous m'avez données

  9. #9
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par tiresias54 Voir le message
    Je me suis renseigné, il parait que le gars qui a écrit la librairie est mort
    Ouais, de honte...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  10. #10
    Membre chevronné
    Inscrit en
    Juillet 2012
    Messages
    231
    Détails du profil
    Informations forums :
    Inscription : Juillet 2012
    Messages : 231
    Par défaut
    @tiresias54 : tu fait du FORTRAN ou du Fortran ?
    Dis autrement, tu fais du Fortran 77 (ou inférieur) ou du Fortran 90 (ou supérieur) ?

    Citation Envoyé par Sve@r
    Au passage on remarquera que la fonction se nomme falloc_ alors que le code fortran appelle juste falloc.
    Les compilateurs Fortran ajoute un underscore aux noms de fonctions. Ajouter cet underscore à la main dans le code C est une des façons d’interfacer les deux.

    Citation Envoyé par Sve@r
    De plus la fonction est sensée recevoir des adresses mais le code Fortran passe des valeurs
    Fortran passe les paramètres par référence en général.

    Citation Envoyé par Sve@r
    mais je présume que c'est l'usage quand on interface Fortran/C.
    C’est tout à fait ça.

    Citation Envoyé par Sve@r
    Bon, ceci dit, voici ce qui me choque: déjà on ne caste plus un malloc depuis que celui-ci renvoie un void*.
    Vu la tête du code, c’est du vieux C (pré-ANSI), donc malloc devait renvoyer char* à cette époque.

    Citation Envoyé par Médinoc
    Ça fait bizarre, tous tes paramètres déclarés en int*, sans aucune notion de type
    Déclaration à la syntaxe K&R (pré-ANSI donc), toujours valide mais dépréciée (Cf. la normedu C99 par exemple, 6.9.1 Function definitions, page 155) car il y a pas mal d’inconvénient (dont pas de vérification de types entre autres).

  11. #11
    Membre chevronné
    Inscrit en
    Juillet 2012
    Messages
    231
    Détails du profil
    Informations forums :
    Inscription : Juillet 2012
    Messages : 231
    Par défaut
    Bon, je viens de faire un test et, à part le fait que le code soit écrit dans un style très vieux, il semble fonctionner correctement (à condition que la taille d’un pointeur soit inférieure ou égale à la taille d’un int).

    Soit le code suivant (je n’ai rien modifié par rapport au code d’origine, juste ajouter des printf/print :
    testlib.f
    Code fortran : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    program testlib
     
      integer nelem,elsize,work,tbaddr,offset
      nelem=10
      elsize=1
      work=0
      tbaddr=0
      offset=0
     
      print *, nelem, elsize, work, tbaddr, offset
      call falloc(nelem,elsize,work,tbaddr,offset)
      print *, nelem, elsize, work, tbaddr, offset
    end program testlib
    falloc.c
    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
    25
    26
    27
    28
    29
    30
    31
    #include <stdlib.h>
    #include <stdio.h>
     
    falloc_(nelem,elsize,basevec,addr,offset)
    int *nelem,*elsize,*basevec,*addr,*offset;
    {
       int noct;
       int adbase;
       int *ptr;
       int rest;
     
       if( *elsize > 8)
          noct=(*nelem + 1) * (*elsize); /* Nombre d'octets */
       else
          noct=(*nelem)*(*elsize); /* Nombre d'octets */
     
       if(noct<=0){
          *addr=0;
          printf("noct <  0 bizarre \n");
          return;
       }
     
       ptr=(int *) malloc(noct); /* Allocation */
       /*(int *)*addr=ptr; */
       *addr=(int)ptr;
       adbase=(int)basevec;
       *offset=(*addr-adbase)/(*elsize);
       rest=(*addr-adbase)-(*offset) * (*elsize);
       if(rest!=0) *offset=*offset+1;
       printf("%d %d\n", *addr, *offset);
    }

    Résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    % gcc -m32 -c falloc.c
    % gfortran --std=legacy -ffree-form -m32 -o tiresias54 testlib.f falloc.o
    % ./tiresias54
              10           1           0           0           0
    135003072 135968036
              10           1           0   135003072   135968036
    Les valeurs obtenues dans le codeFotran sont bien celles produites dans le code C donc l’interfaçage semble OK.
    Du coup, est ce que tu aurais un exemple de code qui reproduit une erreur de segmentation ?

    Bon j’ai dû compiler en 32-bit, sinon la conversion pointeur->int aurait été foireuse.

    (Désolé pour le double post).

  12. #12
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut
    merci grim, ton idée m'a mis sur la piste: en remplaçant les integer par des integer*4 et les real par des real*4 dans mon code appellant, j'ai résolu le probème

    Pour info le code a plus de 20 ans.

  13. #13
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Je pense que tu devrais plutôt faire l'inverse: Utiliser des size_t et intptr_t côté C au lieu des int (plus un void** pour le retour du pointeur, au lieu d'un int*).
    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.

  14. #14
    Membre très actif
    Profil pro
    ingénieur
    Inscrit en
    Novembre 2011
    Messages
    165
    Détails du profil
    Informations personnelles :
    Localisation : France, Tarn (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur

    Informations forums :
    Inscription : Novembre 2011
    Messages : 165
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Je pense que tu devrais plutôt faire l'inverse: Utiliser des size_t et intptr_t côté C au lieu des int (plus un void** pour le retour du pointeur, au lieu d'un int*).
    du coup ce code te parait-il pertinent (et sûr)? (les lignes que j'ai modifiées sont en gras). Et j'ai du ajouter un

    en début de fichier *.c

    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
    21
    22
    23
    24
    25
    26
    int *nelem,*elsize,*basevec,*addr,*offset;
    {
       size_t noct;
       size_t adbase;
       size_t *ptr;
       size_t rest;
     
       if( *elsize > 8)
          noct=(*nelem + 1) * (*elsize); /* Nombre d'octets */
       else
          noct=(*nelem)*(*elsize); /* Nombre d'octets */
     
       if(noct<=0){
          *addr=0;
          printf("noct <  0 bizarre \n");
          return;
       }
     
       ptr=(void **) malloc(noct); /* Allocation */
       *addr=(intptr_t)ptr;
       adbase=(intptr_t)basevec;
       *offset=(*addr-adbase)/(*elsize);
       rest=(*addr-adbase)-(*offset) * (*elsize);
       if(rest!=0) *offset=*offset+1;
       printf("%d %d\n", *addr, *offset);
    }
    quoiqu'il en soit lorsque je compile j'ai des warnings du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    "falloc.c", line 19: warning: assignment type mismatch:
            pointer to unsigned long "=" pointer to pointer to void
    avec sunstudio cc

    ou bien égalemert (si je compile avec gnu gcc):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    falloc.c: In function ‘falloc_’:
    falloc.c:19: warning: assignment from incompatible pointer type

  15. #15
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 397
    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 397
    Par défaut
    Retirer le cast de malloc() devrait corriger le warning.
    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.

  16. #16
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Ça fait bizarre, tous tes paramètres déclarés en int*, sans aucune notion de type (tbaddr devrait être au minimum void**) ou de constante (pour les paramètres que la fonction ne modifie pas).
    manière de déclaration pré C90....


    Quant au problème, outre le fait que Fortran passe par référence, il y a un cas particulier pour les tableaux (et donc les chaines aussi) : Fortran attend à la suite la taille..

    Mais le mieux est de poster sur le forum Fortran si des questions subsistent.. Eux sont habitués, ça arrive tout le temps les conversions dans un sesn et dans l'autre...

Discussions similaires

  1. Erreur de segmentation avec fortran: c'est quoi?
    Par VauRDeC dans le forum Fortran
    Réponses: 2
    Dernier message: 29/09/2010, 09h06
  2. Erreur de segmentation (Inconnue)
    Par Dark-Meteor dans le forum C
    Réponses: 5
    Dernier message: 08/09/2005, 13h42
  3. [Dev-C++] Erreur de segmentation...
    Par sas dans le forum Dev-C++
    Réponses: 11
    Dernier message: 26/03/2005, 14h25
  4. erreur de segmentation
    Par transistor49 dans le forum C++
    Réponses: 10
    Dernier message: 15/03/2005, 11h18
  5. [Visual Fortran] Erreur de compilation
    Par Julito dans le forum Fortran
    Réponses: 1
    Dernier message: 04/03/2005, 21h24

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