PDA

View Full Version : [c] Come fare con getchar??


cletopolonia
10-07-2007, 11:02
ragazzi ho 1 problemone con un progetto...

Devo leggere degli input da tastiera così composti:

i è una funzione insert
l è una funzione insert_length

i primo_nome secondo_nome (devo leggere 1 char e 2 stringhe)

l primo_nome num_seq (devo leggere 1 char, 1 stringa e 1 intero)

io pensavo a:


do {
printf("Cosa vogliamo fare??\n");
scelta = getchar();

/* leggo l'input nel formato sopra descritto*/

switch(scelta) {
case 'i':
/* come assegno le stringhe di primo_nome e secondo_nome???*/
insert(primo_nome, secondo_nome);
break;

case 'l':
insert_length(primo_nome, numero_seq);
break;

case 'f':
printf("...e qui si esce dal programma..\n\n");
break;

default:
printf("Mi sa che hai sbagliato tasto..\n\n");
break;
}
} while (scelta != 'f');


così facendo non funziona..
ho porvato con le scanf ma era 1 disastro..
come posso risolvere il porblema con getchar()??

ringrazio in anticicpo tutti coloro che cercheranno di aiutarmi.

yorkeiser
10-07-2007, 16:31
Cos'è che ti fa casino con scanf?


printf("Cosa vogliamo fare??\n");
fflush(stdin);
scanf("%c",&scelta);
switch(scelta) { ...

cletopolonia
10-07-2007, 20:06
Ti ringrazio anticipatamente per la dritta
Sono alle prime armi e qst << fflush(stdin) >> non sapevo esistesse..
Ora provo ad utilizzarlo..

cletopolonia
11-07-2007, 10:22
ma il mio problema è che devo elaborare 3 input e non solo quello della scelta..

yorkeiser
11-07-2007, 11:38
fflush svuota il buffer (in questo caso lo standard input) da caratteri "sporchi" che potrebbero esservi rimasti memorizzati.

Non ho capito qual'è il problema per la lettura delle altre variabili... Le dichiari, allochi evenutalmente lo spazio nel caso delle stringhe, e fai la lettura nello stesso modo

cletopolonia
11-07-2007, 11:52
io ho 1 cosa simile...

char *primo_nome;
char *secondo_nome;

do {
printf("Cosa vogliamo fare??\n");
scelta = getchar();

scanf("%c %s %s", &scelta, &primo_nome, &secondo_nome);
switch(scelta) {
case 'i':
printf("Qui mettero' inserisci..\n");
/* qui mi stampa errore, cioè chiude il prompt e blocca l'esecuzione /*
printf("primo nome: %s\n", primo_nome);
printf("secondo nome: &s\n\n", secondo_nome);


dove sbaglio??

mapomapo
11-07-2007, 12:19
char *primo_nome;
non è una stringa!!!!
è un puntatore a char che può diventare una stringa se e soltanto se fai una chiamata alla funzione malloc().

char primo_nome[20];

è una stringa da 20byte.
una volta dichiarata una cosa di questo genere ha senso una scanf %s, altrimenti no.

Vito

yorkeiser
11-07-2007, 12:27
Allora, andiamo per punti:

1) Ti conviene togliere la getchar dal momento che a questo punto non avrebbe più senso.

2) Le stringhe, quando dichiarate coi puntatori, vanno allocate in memoria prima di essere utilizzate. Ovvero:
char* stringa = (char*)malloc(LUNGHEZZA_STRINGA);

3) Nella scanf, è giusto passare l'indirizzo del char, e non il char stesso, tramite l'operatore &; nel caso delle stringhe però, dal momento che si tratta già di puntatori e quindi di riferimenti in memoria, non devi più passarle con quell'operatore.

Rieplilogando, hai bisogno di una cosa del genere per l'assegnamento delle variabili:


int lunghezza = 20;
char *primo_nome;
char *secondo_nome;
primo_nome = (char*)malloc(lunghezza);
secondo_nome = (char*)malloc(lunghezza);
printf("Cosa vogliamo fare??\n");
fflush(stdin);
scanf("%c %s %s", &scelta, primo_nome, secondo_nome);
printf("%c %s %s", scelta, primo_nome, secondo_nome);

cletopolonia
11-07-2007, 19:52
mamma mia che vergona..
vi ringrazio infinitamente..
ok, ora è perfetto!

Ma c'è 1 nuovo problema: poi ho 1 switch e non sempre dalla scanf prendo 3 argomenti uguali, anzi mai...
insert ............ %c %s %s
insert_length .. %c %s %d
end .............. %c



int lunghezza = 20;
char *primo_nome;
char *secondo_nome;
primo_nome = (char*)malloc(lunghezza);
secondo_nome = (char*)malloc(lunghezza);

while (scelta != 'f') {
fflush(stdin);
printf("Cosa vogliamo fare??\n");
scanf("%c %s %s", &scelta, primo_nome, secondo_nome);
switch(scelta) {
case 'i':
printf("Qui mettero' inserisci..\n");
/*insert(primo_nome, secondo_nome);*/
break;
case 'l': /* qui la scanf dovrebbe avere una %c, %s e %d */
insert_length(primo_nome, numero_seq); /* num seq è un intero!!! */
break;

case 'f': /* qui la scanf dovrebbe avere solo un %c, %c */
printf("...e qui si esce dal programma..\n\n");
break;

default:
printf("Mi sa che hai sbagliato tasto..\n\n");
break;
}
}


ma in c non esiste qualcosa come lo stringtokenizer di java??

cletopolonia
12-07-2007, 21:45
up

danny2005
13-07-2007, 09:12
Secondo me devi cambiare impostazione; con switch ho sempre usato o costanti carattere o interi;
quindi nel tuo programma il discriminante deve essere switch(scelta), con scelta intero o costante carattere e poi nei vari case metti quello che ti serve: printf, scanf, richiami una funzione....
Anche potendolo fare mi sembra un'inutile complicazione....

cletopolonia
16-07-2007, 09:02
ma in c non esiste qualcosa come lo stringtokenizer di java??


Grazie a tutti, siete stati molto gentili ed utili..
Non posso fare in un altro modo perchè non ho scelta!
Al massimo posso prendere tutta la stringa di input, spazi compresi e poi dividerla... e in base al primo char entrare nello switch.

cletopolonia
25-09-2007, 11:18
*Massi 6 un lamer*

71104
25-09-2007, 12:31
scusate ma in questi giorni ho trovato un nuovo ragazzo (siamo per le coppie di fatto) e non ho molto tempo per fare le prove. potreste essere più precisi e limitarmi lo sbattimento?
:sofico: questa è da signa :|