Rechercher : dans
Par :

DEV en C Switch / CASE

Dernière réponse le 5 sep 2007 à 14:27:24 tibus27, le 3 sep 2007 à 13:07:34 
 Signaler ce message aux modérateurs

Bonjour,

J'ai un petit pb avec un switch case qui tourne dans une boucle.
Il y a 4 cas dans mon menu, quand je tape un chiffre non compris il va bien dans le default et revient au menu, le probleme c'est quand je tape une lettre, il va bien dans le default mais par un boucle infini, il ne prend pas en compte le "break". la variable pour le menu est de type "char".

Quelqu'un a t'il une idée de ma boulette ?

Merci

Tibus :-)

Meilleures réponses pour « DEV en C Switch / CASE » dans :
Compiler un programme en C avec Dev C++ sous Vista VoirIl est très probable que vous ayez des problèmes lors de la compilation d'une source C sous Vista avec Dev C++. Solution rapide de secours: le compilateur g++ Voici une astuce pour Dev-Cpp : Aller dans "Outils" -> "Options du compilateur" puis...
Télécharger le contenu d'une page WEB distante VoirIntroduction Installation sous Linux (Ubuntu / Debian) Installation sous Windows Dev C++ Microsoft Visual C++ Petite exploration des fonctions de libcurl Un exemple: télécharger la page d'accueil de CCM Notre fichier source Compilation...
Langage C - Les structures conditionnelles VoirQu'est-ce qu'une structure conditionnelle ? On appelle structure conditionnelle les instructions qui permettent de tester si une condition est vraie ou non. Ces structures conditionnelles peuvent être associées à des structures qui se répètent...

3

tibus27, le 3 sep 2007 à 14:31:44

Char choixMenu;

while (choixMenu != 4)
{
affichemenu();
scanf("%ld",&choixMenu);
printf("\n\n");
switch (choixMenu)
{
case 1:
[instruction]
break;
case 2:
[instruction]
break;
case 3:
[instruction]
break;
case 4:
printf("A bientot\n");
break;
default:
printf("vous n'avez pas entre un nombre correct :\n\n");
break;
}
}

Configuration: Windows XP
Internet Explorer 7.0

Répondre à tibus27

4

dubcek, le 3 sep 2007 à 14:41:50

Int choixMenu me semble plus logique pour une comparaison numérique (!=4) et un scanf en %ld.
d'ailleur pourquoi %ld, %d suffirait ?

Répondre à dubcek

5

tibus27, le 3 sep 2007 à 15:45:54

Malheureusement non, le problème reste le même.

Répondre à tibus27

6

mp280272, le 3 sep 2007 à 20:03:29

Salut test comme cela sinon passe par do while c'est-a-dire faire jusqu'a plus indiqué dans le context

char choixMenu ="";

while (choixMenu !=" 4")
{
affichemenu();
scanf("%c",&choixMenu); //pour %c je suis plus sur peut etre %s
printf("\n\n");
switch (choixMenu)
{
case "1":
[instruction]
break;
case "2":
[instruction]
break;
case "3":
[instruction]
break;
case "4":
printf("A bientot\n");
break;
default:
printf("vous n'avez pas entre un nombre correct :\n\n");
break;
}
}
mp280272@yahoo.fr

Configuration: Windows Vista
Internet Explorer 7.0

Répondre à mp280272

7

tibus27, le 4 sep 2007 à 08:51:44

Je viens de tester, le problème de boucle infinie ne revient pas maintenent il ne rentre plus dans les case quand je tape 1 par example.
J'ai donc testé le Do / while et le problème est le même.

J'ai réussi à contourner le problème, seul hic il n'affiche pas le menu.

int choixMenu="";

do
{
affichemenu();
scanf("%ld",&choixMenu);
printf("\n\n");
switch (choixMenu)
{
case 1:
[instruction]
break;
case 2:
printf("Voici la liste des identifiants :\n\n");
affichage(i);
break;
case 3:
printf("Veuillez entrer l'identifiant recherche :\n\n");
scanf("%s",buf);//chaine recherché
recherche(i);
break;
case 4:
printf("A bientot\n");
return (0);
default:
printf("vous n'avez pas entre un nombre correct ! \n\n");
choixMenu=5;
break;
}

}while (choixMenu != 5);

Répondre à tibus27

8

dubcek, le 4 sep 2007 à 10:09:44

Avec int choixMenu il faut lire %d pas %ld, l c'est pour long

scanf("%d",&choixMenu);

Répondre à dubcek

9

tibus27, le 4 sep 2007 à 11:09:31

Non plus, sa fonctionne pas mieux, le problème c'est que après avoir commencer à utiliser le programme, une simple faute de frappe me fait sortir ... grrr

Répondre à tibus27

10

tibus27, le 4 sep 2007 à 11:28:09

Voici un prog qui doit tourner pour faire des tests


void affichemenu()
{
printf("1) Entrer un identifiant\n2) Afficher la liste des identifiants\n");
printf("3) Chercher la position d'un identifiant\n4) Sortir de l'application\n\n");
printf("Veuillez saisir le numero de la fontion :");

}

int main(int argc, char *argv[])
{
int choixMenu="";
int tailleid=0; //taille de l'identifiant.
int i=0;//compteur de saisi.
int j=0;//compteur
int find=1;//paramètre de la recherch

printf("***************************************\nBienvenue dans le programme Identifiant\n***************************************\n\n");

do
{
affichemenu();
scanf("%d",&choixMenu);
printf("\n\n");
switch (choixMenu)
{
case 1:
printf("Veuillez entrer votre identifiant :\n\n");
choixMenu="";
break;
case 2:
printf("Voici la liste des identifiants :\n\n");
choixMenu="";
break;
case 3:
printf("Veuillez entrer l'identifiant recherche :\n\n");
choixMenu="";
break;
case 4:
printf("A bientot\n");
return (0);
default:
printf("vous n'avez pas entre un nombre correct ! \n\nVoici la liste des identifiants : \n\n");
choixMenu=5;
break;
}

}while (choixMenu != 5);
}

Répondre à tibus27

11

mp280272, le 4 sep 2007 à 18:49:59

Voici un progrmme que j'utilise regulierementet qui tourne sans le swith case peut etre que ton compilateur est beuguer sur cette instruction en developpement ne cherche pas trop a perdre de temps réutilise se qui fonctionne .

dans le programme ci-desus si tu declare un int choixmenu; tu ne dois l'initialiser avec ""

#include <stdio.h>
voif AfficherMenu(void)
{
printf("Menu :\n");
printf("1. Saisir un client\n");
--------
printf("5. Quiter le pogrammet\n\n");
printf("Entrez votre choix : ");
}
void SaisirClient(void) {....};
void SaisirProduit(void) {....};
void main (void)
{
int choix;
do
{
AfficherMenu();
scanf("%d", &choix);
if (chois==1) SaisirClient();
else if (choix == 2) ......;
else if (choix == 3) ....;
-------
}
while (choix !=5);
}

si celui-ci ne fonctionne pas change de compilateur

merci de mailler pour ta responce mp280272@yahoo.fr

Répondre à mp280272

12

mp280272, le 4 sep 2007 à 18:58:24

Attention dans le code que je vien de te donner je ne gere pas les erreur de saisie il faut qe tu creer une gestion d'erreur de saisie

Répondre à mp280272

13

tibus27, le 4 sep 2007 à 18:59:08

Le problème c'est que suis obligé d'utiliser le SWITCH / CASE (éducation nationnal..)

Mais je garde cela au cas ou

Merci :-)

Répondre à tibus27

14

mp280272, le 4 sep 2007 à 19:23:06

Dans ce cas fait une gestion des erreurs de saisie

controle que l'utilisateur rentre bien une valeur entiere

ou force la sortie de la boucle do while dans le default exit do

int choixMenu;

do
{
affichemenu();
do
{
scanf("%ld",&choixMenu);
}
while (controle de la sisier)

printf("\n\n");
switch (choixMenu)
{
case 1:
[instruction]
break;
case 2:
printf("Voici la liste des identifiants :\n\n");
affichage(i);
break;
case 3:
printf("Veuillez entrer l'identifiant recherche :\n\n");
scanf("%s",buf);//chaine recherché
recherche(i);
break;
case 4:
printf("A bientot\n");
return (0);
default:
printf("vous n'avez pas entre un nombre correct ! \n\n");
choixMenu=5;
break;
}

}while (choixMenu != 5);

je pense que je vais bientot laisser tomber mes aides sur CCM rale bole des moderateurs sur se portail
qui mainteant ne souhaite plus que je demande aux personnes de m'esposer en detail leur prob par mail
je test encore une fois ou deux si cela continu je pase sur un autre forum et j'enviterais tout autre personnes ne solicitajnt pas d'aides mes offreanr une aides de faire de même on vraiment trop male recu sur ce forum.

Répondre à mp280272

15

 tibus27, le 4 sep 2007 à 21:56:14

YOUPI j'ai trouvé en me basant sur l'une de vos réponses, le type de la variable est char et la valeur correspondante du case et celle de la table ASCII 1=49... ect

MERCi pour votre aide voici le code pour ceux qui aurai le problème.

char choixMenu="";

do
{
affichemenu();
scanf("%s",&choixMenu);
printf("\n\n");
switch (choixMenu)
{
case 49: //valeur ascii du chiffre 1
printf("Veuillez entrer votre identifiant :\n\n");
choixMenu="";
break;
case 50://valeur ASCII du chiffre 2
printf("Voici la liste des identifiants :\n\n");
choixMenu="";
break;
case 51://valeur ASCII du chiffre 3
printf("Veuillez entrer l'identifiant recherche :\n\n");
choixMenu="";
break;
case 52://valeur ASCII du chiffre 4
printf("A bientot\n");
return (0);
default:
printf("vous n'avez pas entre un nombre correct ! \n\n");
break;
}
}while (choixMenu != 52);

Répondre à tibus27