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

Caml Discussion :

Warning vs Error


Sujet :

Caml

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2007
    Messages : 63
    Points : 54
    Points
    54
    Par défaut Warning vs Error
    Salut tous,

    Je rencontre un bug assez étrange dans un de mes codes.
    j'ai plusieurs conditions les unes après les autres, de la forme:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    if (mat.(a).(b) = 1)
      then
        begin
          List.map (fun x -> compteur_t := !compteur_t-1) !voisins_d;
          voisins_d := c :: !voisins_d
        end;
    Là, ça compile aves un warning:
    Warning S: this expression should have type unit.

    maintenant, si j'ai juste:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if (mat.(a).(b) = 1)
      then
        List.map (fun x -> compteur_t := !compteur_t-1) !voisins_d;
    là, il y a une erreur:
    This expression has type unit list but is here used with type unit

    Caml ne m'avait pas habitué à ça... Si je vois à peu près pourquoi il me dit ça, je ne comprends pas pourquoi il ne bugge pas dès le premier cas.

    Quelqu'un peut m'expliquer??

  2. #2
    LLB
    LLB est déconnecté
    Membre expérimenté
    Inscrit en
    Mars 2002
    Messages
    967
    Détails du profil
    Informations forums :
    Inscription : Mars 2002
    Messages : 967
    Points : 1 410
    Points
    1 410
    Par défaut
    List.map construit une liste avec les résultats de ta fonction. Si tu ne veux pas récupérer cette valeur, utiliser List.iter.

  3. #3
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Citation Envoyé par Amergin Voir le message
    Quelqu'un peut m'expliquer??
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    List.map (fun x -> compteur_t := !compteur_t-1) !voisins_d;
    Ce code renvoie "unit list", si il est part d'une suite d'instruction on considère bizarre que l'une de ces instructions ne renvoie pas unit puisque le seul intérêt d'une instruction dans une séquence vient de ses effets de bord et que toute valeur renvoyée est perdue (donc ça serait mieux si la valeur renvoyé n'avait aucune signification, comme () ). Par contre la valeur renvoyée par une séquence complète d'instructions est la valeur renvoyée par la dernière instruction de la séquence, donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    voisins_d := c :: !voisins_d
    dans ton premier code et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    List.map (fun x -> compteur_t := !compteur_t-1) !voisins_d;
    dans le second.

    Maintenant il faut voir que "if then else" est toujours une expression en OCaml, c'est-à-dire qu'il doit renvoyer une valeur. Si on omet la branche else alors OCaml doit "inventer" une valeur lorsque la condition est fausse, et cette valeur est () (unit) puisqu'on suppose que "if then" n'est là que pour ses effets de bord et donc la valeur retourné par la branche then doit être du même type : unit.
    C'est le cas de :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    voisins_d := c :: !voisins_d
    mais pas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    List.map (fun x -> compteur_t := !compteur_t-1) !voisins_d;
    D'où ton erreur de type dans le second cas.

    En fait le warning dans le premier cas était justifié : il n'y a aucune raison pour ton expression de renvoyer une liste, ça ne sert à rien et ça gaspille de la place (en supposant que ça ne soit pas optimisé), tu devrais plutôt utiliser List.iter à la place de List.map ou, mieux, écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    compteur_t := !compteur_t - List.length !voisins_d
    (Ou écrire carrément ton code dans un style plus fonctionnel, il y a trop de références !)

    --
    Jedaï

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    63
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2007
    Messages : 63
    Points : 54
    Points
    54
    Par défaut
    Ok! merci, c'est très clair. J'ai tout mis en List.iter, ça marche très bien.

    Bon, j'ai encore du mal à me passer des références, mais ça va venir...

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 26/05/2009, 00h04
  2. [VS2003] set warning as error
    Par fally dans le forum C#
    Réponses: 2
    Dernier message: 20/02/2008, 17h40
  3. [ASE12] mess. erreur : WARNING - Fatal Error 644 occurred at Sep 21 2007 10:27PM.
    Par padraig29 dans le forum Adaptive Server Enterprise
    Réponses: 2
    Dernier message: 28/09/2007, 16h08
  4. Réponses: 1
    Dernier message: 09/06/2006, 17h06
  5. [EasyPHP] Warning: Sablotron error on line 41: wrong expression syntax
    Par moonia dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 3
    Dernier message: 27/03/2006, 14h00

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