Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-08-2010, 15:51   #1
retnI W
Senior Member
 
Iscritto dal: Mar 2005
Messaggi: 2090
[C]Problema con istruzione "switch"

Un programma stupido ed inefficiente (manca un costrutto ciclico per essere "buono") scritto solo per allenarmi coni tipi complessi e il costrutto switch!

Codice:
#include <stdio.h>
#define LunghezzaNome 20
void main ()
{
     int comando;
     typedef struct {char      nome[LunghezzaNome];
                     char      categoria;
                     int       retribuzione;
                     }dipendenti;    
     dipendenti dipendente;
     printf ("inserire 0 per uscire, 1 per definire il nome, 2 per definire la categoria, 3 per definire la retribuzione\n");
     scanf ("%d", &comando);     
     switch (comando)
     {
     case 0: printf ("arrivederci!!");
             break;
     case 1: scanf ("%s", &dipendente.nome);
             break;   
     case 2: printf ("inserire a = autista, c = controllore\n");
             scanf ("%c", &dipendente.categoria);
             break;               
     case 3: scanf ("%d", &dipendente.retribuzione);
             break;      
     }       
     printf ("inserire 0 per uscire, 1 per visualizzare il nome, 2 per visualizzare la categoria, 3 per visualizzare la retribuzione\n");
     scanf ("%d", &comando);
     switch (comando)
     {
     case 0: printf ("arrivederci!!");
             break;       
     case 1: printf ("%s\n", dipendente.nome);
             break;   
     case 2: if (dipendente.categoria == 'a')
             printf ("autista\n");
             else if (dipendente.categoria == 'c')
                  printf ("controllore\n");
             break;
     case 3: printf ("%d\n", dipendente.retribuzione);
             break;      
     }
     getch ();       
}
Quando compilo ed eseguo, inserisco 2 per definire la categoria ma il programma salta direttamente al printf fuori dello switch non permettendomi di selezionare la categoria stessa. Cosa c'è che non va? Avevo pensato ad un errore nella parte:

case 2: printf ("inserire a = autista, c = controllore\n");
scanf ("%c", &dipendente.categoria);
break;

...ditemi voi, grazie!
__________________
Ci sono porte che ti lasciano entrare e uscire
Ma non sono mai aperte. (T. Yorke)

Ultima modifica di retnI W : 18-08-2010 alle 16:09.
retnI W è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2010, 16:05   #2
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
probabilmente è qualche errore legato al fatto che quando inserisci il numero premi anche invio mandando un \n che viene bufferizzato e poi preso come carattere nello scanf, proverei una delle due al posto della riga scanf ("%c", &dipendente.categoria);

Codice:
do {
  dipendente.categoria = getchar();
} while (dipendente.categoria != 'a' && dipendente.categoria != 'c');
o

Codice:
fflush(stdin);
dipendente.categoria = getchar();
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2010, 16:18   #3
retnI W
Senior Member
 
Iscritto dal: Mar 2005
Messaggi: 2090
Grazie. Ho risolto con la prima alternativa. Ma sei vai a compilare, accade anche a te il problema? E' un problema di compilazione oppure dipende dal calcolatore o da come viene caricato il programma in memoria? Se avessi usato una variabile intera anzichè un carattere non avrei riscontrato l'errore?

esempio: "inserire 1 = autista, 2 = controllore"
__________________
Ci sono porte che ti lasciano entrare e uscire
Ma non sono mai aperte. (T. Yorke)
retnI W è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2010, 16:34   #4
retnI W
Senior Member
 
Iscritto dal: Mar 2005
Messaggi: 2090
Effettivamente modificando il tipo del campo dipendente.categoria da char a int e modificando la parte esecutiva a dovere, tutto funziona.

Codice:
#include <stdio.h>
#define LunghezzaNome 20
void main ()
{
     int comando;
     typedef struct {char      nome[LunghezzaNome];
                     int       categoria;
                     int       retribuzione;
                     }dipendenti;    
     dipendenti dipendente;
     printf ("inserire 0 per uscire, 1 per definire il nome, 2 per definire la categoria, 3 per definire la retribuzione\n");
     scanf ("%d", &comando);     
     switch (comando)
     {
     case 0: printf ("arrivederci!!");
             break;
     case 1: scanf ("%s", &dipendente.nome);
             break;   
     case 2: printf ("inserire 1 = autista, 2 = controllore\n");
             scanf ("%d", &dipendente.categoria);             
             break;               
     case 3: scanf ("%d", &dipendente.retribuzione);
             break;      
     }       
     printf ("inserire 0 per uscire, 1 per visualizzare il nome, 2 per visualizzare la categoria, 3 per visualizzare la retribuzione\n");
     scanf ("%d", &comando);
     switch (comando)
     {
     case 0: printf ("arrivederci!!");
             break;       
     case 1: printf ("%s\n", dipendente.nome);
             break;   
     case 2: if (dipendente.categoria == 1)
             printf ("autista\n");
             else if (dipendente.categoria == 2)
                  printf ("controllore\n");
             break;
     case 3: printf ("%d\n", dipendente.retribuzione);
             break;      
     }
     getch ();       
}
Quindi per non avere problemi mi sconsigliare le variabili "char" per le scelte? Il mio obiettivo è quello di creare programmi lineari e sintatticamente corretti dovendo dare SOLO un esame di informatica (a breve) nel mio corso di laurea.
__________________
Ci sono porte che ti lasciano entrare e uscire
Ma non sono mai aperte. (T. Yorke)
retnI W è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2010, 17:58   #5
Darecon
Senior Member
 
Iscritto dal: Sep 2003
Città: Tradate
Messaggi: 396
Se vuoi usare i char ti conviene usare l' fflush(stdin) e non farti troppi problemi, altrimenti usa gli interi, alla file se e' solo per un esame tanto vale, basta che capisci come implementare l'algoritmo..
Darecon è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2010, 02:13   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da Darecon Guarda i messaggi
Se vuoi usare i char ti conviene usare l' fflush(stdin)
Il comportamento di fflush su stdin non è ratificato dallo standard. In teoria fflush(stdin) potrebbe anche non fare niente.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2010, 08:53   #7
Darecon
Senior Member
 
Iscritto dal: Sep 2003
Città: Tradate
Messaggi: 396
Quote:
Originariamente inviato da cionci Guarda i messaggi
Il comportamento di fflush su stdin non è ratificato dallo standard. In teoria fflush(stdin) potrebbe anche non fare niente.
Acc, non lo sapevo.. Pero' sia su gcc sia su compilatore ms dovrebbe andare.. E se lo scopo e' solo far funzionare il programma per l'esame nno credo sia cosi' grave.. no?
Darecon è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2010, 09:30   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
La soluzione migliore e soprattutto aderente allo standard è svuotare lo stdin dopo aver fatto la scanf con

while(getchar() != '\n');

Sicuramente la scanf almeno uno '\n' lo lascia.
Inoltre per saltare il primo switch basta immettere un carattere qualsiasi diverso da 0, 1, 2, 3 Ovviamente è un comportamento che non si dovrebbe volere.

Ultima modifica di cionci : 19-08-2010 alle 09:33.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2010, 13:32   #9
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da retnI W Guarda i messaggi
Grazie. Ho risolto con la prima alternativa. Ma sei vai a compilare, accade anche a te il problema? E' un problema di compilazione oppure dipende dal calcolatore o da come viene caricato il programma in memoria? Se avessi usato una variabile intera anzichè un carattere non avrei riscontrato l'errore?

esempio: "inserire 1 = autista, 2 = controllore"
non l'ho provato, ma sono sicuro che mi darebbe lo stesso problema, non è una questione di compilatore, è semplicemente il modo in cui viene gestito l'input nella libreria standard, che bufferizza tutto quello che si inserisce per motivi di efficienza
tuccio` è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Ecovacs presenta la gamma 2026: paviment...
Efficienza energetica fino a 2.000 volte...
Lenovo 360: il programma di canale dell'...
Appena 10.000 qubit per rompere la critt...
Analisi dei transistor durante il funzio...
Attacco informatico a Booking.com: espos...
A quattro mesi dal divieto dei social ne...
NVIDIA GeForce RTX 5060 e 5060 Ti: in ar...
Rebellions, Arm e SK Telecom, nuova alle...
Modernizzazione delle app: Red Hat OpenS...
Nel mirino di Google c'è il back ...
PRAGMATA in bundle con GeForce RTX 5000:...
Le novità MOVA per il 2026: robot e impi...
Windows, stop all'attivazione telefonica...
ASUS porta la serie TUF nel formato Mini...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 01:45.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v