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 :

Opérateurs "short-circuit" et récursivité non-terminale


Sujet :

Caml

  1. #1
    Membre éclairé
    Avatar de GnuVince
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2004
    Messages
    679
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2004
    Messages : 679
    Points : 803
    Points
    803
    Par défaut Opérateurs "short-circuit" et récursivité non-terminale
    Soit le code suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    let rec boucle i =
      match i with
        | 0 -> true
        | _ -> i = i && boucle (i-1)
    in boucle 1000000;;
    Si on utilisait un opérateur comme l'addition, on risquerait un débordement de la pile; qu'en est-il avec les opérateurs && et || qui sont à short-circuit?

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    832
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 832
    Points : 1 104
    Points
    1 104
    Par défaut
    Les opérateurs short-circuit préservent bien la tail-rec, comme un test te l'aurait appris.

    La description des opérateurs booléens du manuel ne mentionne pas la tail-rec (je pense me souvenir que la tail-rec n'est pas définie dans le manuel, mais seulement par l'implémentation), mais elle propose des formes équivalentes ("if a then true else b", etc.) qui préservent la tail-rec.

  3. #3
    Membre éprouvé
    Avatar de InOCamlWeTrust
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    1 036
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 1 036
    Points : 1 284
    Points
    1 284
    Par défaut
    && et || sont considérés des opérateurs de flot par à peu près tous les compilateurs classiques, et Caml n'échappe pas à la règle. S'ils avaient été considérés uniquement de simples opérateurs arithmétiques, cela aurait été une faute (de débutant) commise par les personnes ayant écrit le compilateur.

  4. #4
    Membre régulier Avatar de smatador
    Homme Profil pro
    Inscrit en
    Mars 2006
    Messages
    57
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 57
    Points : 78
    Points
    78
    Par défaut
    Citation Envoyé par InOCamlWeTrust Voir le message
    && et || sont considérés des opérateurs de flot par à peu près tous les compilateurs classiques, et Caml n'échappe pas à la règle. S'ils avaient été considérés uniquement de simples opérateurs arithmétiques, cela aurait été une faute (de débutant) commise par les personnes ayant écrit le compilateur.
    Malheureusement, c'est une erreur qui a été commise par les concepteurs du langage VBA... et ce n'est pas la seule .

  5. #5
    Membre éprouvé
    Avatar de Cacophrene
    Homme Profil pro
    Biologiste
    Inscrit en
    Janvier 2009
    Messages
    535
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Biologiste

    Informations forums :
    Inscription : Janvier 2009
    Messages : 535
    Points : 1 125
    Points
    1 125
    Par défaut
    Bonsoir,

    Citation Envoyé par smatador
    Malheureusement, c'est une erreur qui a été commise par les concepteurs du langage VBA... et ce n'est pas la seule
    Le langage VBA est une erreur.

    Non ce n'est pas une incitation à troller.

    Cordialement,
    Cacophrène

  6. #6
    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
    Citation Envoyé par InOCamlWeTrust Voir le message
    && et || sont considérés des opérateurs de flot par à peu près tous les compilateurs classiques, et Caml n'échappe pas à la règle. S'ils avaient été considérés uniquement de simples opérateurs arithmétiques, cela aurait été une faute (de débutant) commise par les personnes ayant écrit le compilateur.
    Il n'en reste pas moins que ce cas particulier, géré magiquement par le compilateur, introduit des comportements bizarres.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    # (&&) false  (1/0 = 2);;
    - : bool = false
    # let f = (&&) in f false  (1/0 = 2);;
    Exception: Division_by_zero.
    Et même :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    # false && (1/0 = 2);;
    - : bool = false
    # let (&&) = (&&);;
    val ( && ) : bool -> bool -> bool = <fun>
    #  false && (1/0 = 2);;
    Exception: Division_by_zero.
    En pratique, ça fait beaucoup plus de bien que de mal, mais c'est un peu dommage sur le plan théorique.

  7. #7
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    832
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 832
    Points : 1 104
    Points
    1 104
    Par défaut
    Ça ne me semble pas aberrant non plus. Le comportement est simple à décrire sémantiquement :
    - `a op b` et `(op) a b` sont équivalents
    - quand `(op)` est passé par valeur (plutôt qu'appelé directement), on passe implicitement `(fun a b -> a op b)`

Discussions similaires

  1. Quote et double quote
    Par aktos dans le forum Langage
    Réponses: 8
    Dernier message: 05/01/2007, 19h55

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