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 :

Problème de compilation


Sujet :

C++

  1. #1
    Membre éclairé Avatar de tintin72
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    663
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 663
    Par défaut Problème de compilation
    Bonjour,

    J'ai un petit souci lors de la compilation:

    warning: comparison between signed and unsigned integer expressions

    Apparement les warnings viennent de la fonction size() de la STL sur des lignes du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if(total > monTableau.size())  total = monTableau.size();
    ou encore:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    for(int i = 0; i < monTableau.size(); i++)
    C'est drôle car sous Dev C++ ça compile sans pb et sous CodeBlocks j'ai ces warnings, pourtant ils utilisent tous les deux le même compilateur (GCC)

    d'ou vient le pb et comment le résoudre ?

    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
    Je crois que Dev-C++ ne met aucun warning si tu ne lui demande pas explicitement.

    déclare i de type size_t.
    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
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 4 290
    Billets dans le blog
    2
    Par défaut
    Peut-être que les options du compilateurs sont différentes (vérifier le niveau de warning).

    Sinon, déclarer i de type size_t est une solution, mais si tu dois ensuite utiliser i dans ta boucle, il y a de fortes chances que tu aies besoin de le caster en int. Donc une autre solution consiste à caster directement le résultat de size():
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for (int i=0; i<(int) monTableau.size(); ...
    Mais quoi qu'il en soit, je ne pense pas que ce warning soit bien grave.

  4. #4
    Membre chevronné Avatar de xxiemeciel
    Inscrit en
    Juin 2005
    Messages
    371
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 371
    Par défaut
    Salut,

    c'est tout simplement parceque size() de la STL retourne un unsigned int car une size ne peux pas etre negatif.

  5. #5
    Membre confirmé Avatar de harsh
    Inscrit en
    Février 2005
    Messages
    229
    Détails du profil
    Informations forums :
    Inscription : Février 2005
    Messages : 229
    Par défaut
    Oui... semble logique que size () retourne un entier non signé (rarement negatif la taille d'un tableau), donc soit tu ignores, soit je pencherais plus pour incrementer un entier non signe

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    unsigned int i;
    for (i=0; i<tab.size(); ++i) {}
    L'argument du futur cast de i en int est toutefois effectivement a prendre en compte...

  6. #6
    Expert confirmé
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 296
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 296
    Par défaut
    TypeDuTableau::size_type correspondra toujours à ce qui est renvoyé par TypeDuTableau::size(), dans le cas des tableaux et autres conteneurs standardisants. C'est aussi le type attendu par l'opérateur [] du tableau/conteneur.

    Sinon l'écart de compilation devait venir des options de compilation que tu utilisais par défaut. Je soupçonne que tu n'utilisais pas de Makefile que tu gérais à la main, mais laissais faire ces EDI.
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

Discussions similaires

  1. problème de compilation sous visual C++
    Par fabmili dans le forum MFC
    Réponses: 4
    Dernier message: 08/02/2004, 19h52
  2. problème de compil devc++ socket
    Par stefdem dans le forum Autres éditeurs
    Réponses: 2
    Dernier message: 11/12/2003, 11h33
  3. Réponses: 1
    Dernier message: 29/10/2003, 12h16
  4. Problème de compilation de la DLL du XMLRad
    Par [DreaMs] dans le forum XMLRAD
    Réponses: 2
    Dernier message: 16/04/2003, 16h46
  5. Réponses: 1
    Dernier message: 27/05/2002, 01h44

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