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 :

Erreur : "was not declared in this scope"


Sujet :

C++

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 5
    Points : 6
    Points
    6
    Par défaut Erreur : "was not declared in this scope"
    Bonjour à tous

    Je suis débutant programmation, et je bloque sur un petit problème pour une compilation.

    J'ai la procédure suivante :

    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
    // PROCEDURE DE LECTURE D'UNE SUITE
    void lire_suite (t_tab_r & g, int & lg)
    {
    	int cpt;
    	char choix;
    	cpt=0;
    	do {
    		cin >> g[cpt];
    		cpt=cpt+1;
    		cout << "Ajouter une valeur ? [O/N]";
    		cin >> choix;
    		if (choix !=o || choix !=n || choix !=O || choix !=N) {
    			do {
    				cout << "Les lettres acceptés sont 'O' ou 'N'. Ajouter une valeur ? [O/N]";
    				cin >> choix;
    			} while (choix!=o || choix!=n || choix!=O || choix!=N);
    		}
    	} while (choix !=o || choix !=O || cpt !=LGMAX);
    	lg=cpt-1;
    }
    Comme vous le voyez c'est un truc très simple, cependant je ne comprend pas pourquoi à la compilation, Xcode me renvoit les erreurs suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp: In function 'void lire_suite(float (&)[14], int&)':
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:37: error: 'o' was not declared in this scope
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:37: error: 'n' was not declared in this scope
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:37: error: 'O' was not declared in this scope
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:37: error: 'N' was not declared in this scope
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:43: error: 'o' was not declared in this scope
    /Users/Adrien/Documents/Dev/S2_TP2_PART1/main.cpp:43: error: 'O' was not declared in this scope
    je vous poste mon header pour peu que ça puisse aider :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    #include <cstdlib>     // bibliothËque c standart
    #include <iostream>    // flux d'entrÈe sortie
    #include <iomanip>     // manipulateurs de flux              
     
    using namespace std;   // permet d'utiliser les flux cin et cout
    Voilà, je ne comprend pas ce qu'il se passe, c'est peut être une erreur bête mais j'avoue bloquer et en cherchant sur google je n'ai rien trouvé pouvant me dépanner, je ne sais même pas si ma procédure marche dans l'optique de ce que je veux faire je l'ai redigé en algo et ma traduction en C++ ne passe pas au compilateur, voilà.

    D'avance merci !

  2. #2
    Candidat au Club
    Inscrit en
    Août 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Il manque les quote autours des caractères dans le if :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (choix !='o' || choix !='n' || choix !='O' || choix !='N')
    Sans les quote ces caractères sont consideres par le compilateur comme des noms de variable qui n'ont pas été déclarées. D'où l'erreur.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    5
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 5
    Points : 6
    Points
    6
    Par défaut
    excellent, je te remercie. Je me doutais bien que c'était une erreur bête

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Attention, ce test sera toujours vrai, car tu as mis des OU logiques au lieu de ET.

    Si choix est égal à 'o', il sera forcément différent de 'n', donc...

    Note: C'est une erreur commune. Tout le monde la fait un jour ou l'autre.
    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.

  5. #5
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Points : 13 017
    Points
    13 017
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Attention, ce test sera toujours vrai, car tu as mis des OU logiques au lieu de ET.

    Si choix est égal à 'o', il sera forcément différent de 'n', donc...

    Note: C'est une erreur commune. Tout le monde la fait un jour ou l'autre.
    Idem pour le do/while du niveau au dessus.

    Sinon, tu peux aussi faire quelque chose comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
       std::string const valide="oOnN";
       char choix;
       std::cout << "Ajouter une valeur ? [O/N]\n";
       while((std::cin>>choix)&&(valide.find(choix)==valide.npos))
       {
          std::cin.ignore( std::numeric_limits<std::streamsize>::max(), '\n' );
          std::cout << "Les lettres acceptés sont 'O' ou 'N'. Ajouter une valeur ? [O/N]\n";
       }
    Ce qui permettrait d'exporter la chaine valide ailleurs et de pouvoir remplacer facilement o/n par y/n (valide="yYnN").

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

Discussions similaires

  1. QLabel et erreur "ui was not declared in this scope"
    Par sosdouble dans le forum Débuter
    Réponses: 1
    Dernier message: 24/04/2012, 19h42
  2. error : 'tr' was not declared in this scope
    Par jimaitou dans le forum Débuter
    Réponses: 3
    Dernier message: 13/05/2009, 13h54
  3. getaddrinfo was not declared in this scope ?
    Par dr.c0der_ dans le forum C
    Réponses: 2
    Dernier message: 30/04/2009, 02h14
  4. QFormLayout was not declared in this scope
    Par kronos85 dans le forum Débuter
    Réponses: 5
    Dernier message: 11/12/2008, 02h30
  5. Réponses: 3
    Dernier message: 03/06/2007, 15h29

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