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 :

Strlen dans un for = Warning ?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    464
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 464
    Par défaut Strlen dans un for = Warning ?
    Salut !

    A chaque fois que je tente ce genre d'écriture dans mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    ...
    for ( j = 0; j < strlen( chaine ); j++ )
    ...
    j'hérite d'un beau warning :

    "SAISON.c" : W8012 Comparaison de valeurs signées et non signées dans la fonction encodepoints en ligne 39

    Qu'est-ce qu'il se passe au juste ? :

  2. #2
    Membre Expert
    Inscrit en
    Décembre 2004
    Messages
    1 478
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 478
    Par défaut
    Comme indique dans la doc, strlen() renvoie un size_t (tres souvent un unsigned) que tu compares avec un (signed) int. D'ou cet avertissement.
    Je te conseille de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    int size = (int) strlen(chaine);
    for (j = 0; j < size; j++)
    { 
       ...
    }
    cela evite en plus de re-evaluer strlen() a chaque iteration (a moins que la taille varie dans la boucle et que tu joues la-dessus).

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    464
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 464
    Par défaut
    Non, la taille ne varie pas; j'ai fait ça uniquement comme raccourci (et en plus ça évite une variable supplémentaire)...
    Mais bon, si c'est pas permis, alors, ... je me plierai

  4. #4
    Membre chevronné
    Avatar de bigquick
    Profil pro
    Inscrit en
    Août 2002
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 356
    Par défaut
    Ce n'est pas le fait qu'il soit dans le for qui n'est pas permis, mais il faut simplement caster le retour, comme la montré DaZumba. Tu peux aussi bien faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for (j=0; j<(int)strlen(chaine); j++)
    {
    }
    que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int size = (int) strlen(j);
    for (j=0; j<size; j++)
    {
    }
    L'avantage du 2ème est de ne pas recalculer la taille de la chaine à chaque iteration, ce qui est beaucoup plus couteux qu'une variable en plus

  5. #5
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par DaZumba
    Je te conseille de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    int size = (int) strlen(chaine);
    for (j = 0; j < size; j++)
    { 
       ...
    }
    Argh, un cast !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    size_t len = strlen(chaine);
    for (j = 0; j < len; j++)
    { 
       ...
    }

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2003
    Messages
    464
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2003
    Messages : 464
    Par défaut
    Mais enfin, qu'est-que vous avez tous contre les cast ??? Ca a pas été inventé pour rien quand meme ?.... :

  7. #7
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Mike888
    Mais enfin, qu'est-que vous avez tous contre les cast ??? Ca a pas été inventé pour rien quand meme ?.... :
    Ca peut avoir une utilité dans certains cas précis et extrèmement rare (fonctions variadics, par exemple), mais la regle de base c'est "pas de cast".

    'Cast is evil'

    En général, ça sert à masquer les problèmes sans les corriger.

  8. #8
    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
    En l'occurence, Emmanuel, ton code ne corrige pas l'erreur non plus.
    Pour la corriger, il suffit de déclarer j lui aussi en size_t (Surtout que ça m'étonnerait qu'il puisse être négatif dans ton code)
    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.

  9. #9
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    De toute façon, c'est simplement un warning, quand on en connaît la raison et qu'il n'est pas du à une erreur de programmation on peut passer dessus dans un premier temps. Il est vrai que pour la beauté du code...
    De plus, avec les différents compilos du marché, des warnings de l'un ne sont pas signalés parl'autre.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  10. #10
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Médinoc
    En l'occurence, Emmanuel, ton code ne corrige pas l'erreur non plus.
    Pour la corriger, il suffit de déclarer j lui aussi en size_t (Surtout que ça m'étonnerait qu'il puisse être négatif dans ton code)
    Oui, et en plus, c'est à ça que je pensais...
    Comme quoi, le code partiel, c'est pas bon... Comme on ne vérifie rien, on ne fait que des bétises...

Discussions similaires

  1. Réponses: 37
    Dernier message: 02/03/2006, 01h58
  2. [JLabel] JLabel dans boucle for
    Par clairenes dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 06/01/2006, 00h47
  3. Réponses: 4
    Dernier message: 29/12/2005, 19h35
  4. [XML-XPATH] Problème dans un for each
    Par stailer dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 26/12/2005, 12h11
  5. [MySQL] insert into dans un for
    Par pimpmyride dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 11/12/2005, 17h55

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