Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-05-2008, 16:18   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
[C] Buffer lettura scanf

Vorrei riempire delle strutture dinamiche inserendo input da tastiera. Quindi faccio un uso misto delle scanf e di fgets, quest'ultima per gestire input con spazi. Solo che la scanf mi dà problemi, in quanto non svuota il buffer:

Codice:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>




struct record_lista
  { char nome[20];
    char cognome[20];
    char indirizzo[20];
    int numero_civico;
    
  };

typedef struct record_lista persona;

int main(void){

  int dimension;
  int i;
 
  printf("Inserisci la dimensione: \n");
  scanf("\n%d",&dimension);
 

  persona*array_din=(persona*)malloc(sizeof(persona)*dimension);
  
  i=0;
  
  for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  
  printf("Inserisci il nome: \n");
  scanf("\n%d",&array_din[i].nome);
  
  printf("Inserisci il cognome: \n");
  scanf("\n%d",&array_din[i].cognome);

  printf("Inserisci l'indirizzo: \n");
  fgets(&array_din[i].indirizzo,sizeof(array_din[i].indirizzo),stdin);

   printf("Inserisci il numero civico: \n");
   scanf("\n%s",&array_din[i].indirizzo);
 
 
     
   }

   i=0;
   for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  printf("Nome: %s\n",&array_din[i].nome);
  printf("Cognome: %s\n",&array_din[i].cognome);
  printf("Indirizzo: %s\n",&array_din[i].indirizzo);
  printf("Numero civico: %d\n",&array_din[i].numero_civico);
    
     
   }
 
  }
So che mettendo il "\n" all'interno della scanf il problema dovrebbe risolversi. Ma non funziona.. Il programma, dopo aver inserito il nome, mi salta direttamente al numero civico.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 16:20   #2
..::DAVE::..
Senior Member
 
L'Avatar di ..::DAVE::..
 
Iscritto dal: Nov 2006
Città: Mantova
Messaggi: 468
metodo casalingo:
dopo la scanf:

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

legge nel buffer fino a che trova un invio
..::DAVE::.. è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 16:37   #3
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da ..::DAVE::.. Guarda i messaggi
metodo casalingo:
dopo la scanf:

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

legge nel buffer fino a che trova un invio
Mm, ma con getchar non si mette in attesa di un ulteriore immissione dell'utente? Poi non capisco perché non funziona con il "\n" nella scanf. Comunque, facendo come suggerisci , funziona.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 17:40   #4
..::DAVE::..
Senior Member
 
L'Avatar di ..::DAVE::..
 
Iscritto dal: Nov 2006
Città: Mantova
Messaggi: 468
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Mm, ma con getchar non si mette in attesa di un ulteriore immissione dell'utente? Poi non capisco perché non funziona con il "\n" nella scanf. Comunque, facendo come suggerisci , funziona.
a me hanno sempre consigliato di non mettere nulla tranne i codici di formato nella scanf (%d %c %s ecc) anche perchè, pur essendo una stringa che contiene i codici di formato( " "), credo proprio che il compilatore non se ne faccia nulla di altri caratteri.
i caratteri inseriti da tastiera vanno tutti in stdin quindi con la getchar() vai a utilizzare lo stesso buffer della scanf.

Ultima modifica di ..::DAVE::.. : 09-05-2008 alle 17:44.
..::DAVE::.. è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 17:45   #5
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Codice:
NAME
       fflush - flush a stream

SYNOPSIS
       #include <stdio.h>

       int fflush(FILE *stream);

DESCRIPTION
       The  function  fflush()  forces a write of all user-space buffered data
       for the given output or update stream via the stream's underlying write
       function.  The open status of the stream is unaffected.

       If  the  stream  argument  is  NULL,  fflush()  flushes all open output
       streams.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 21:22   #6
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da DanieleC88 Guarda i messaggi
Codice:
NAME
       fflush - flush a stream

SYNOPSIS
       #include <stdio.h>

       int fflush(FILE *stream);

DESCRIPTION
       The  function  fflush()  forces a write of all user-space buffered data
       for the given output or update stream via the stream's underlying write
       function.  The open status of the stream is unaffected.

       If  the  stream  argument  is  NULL,  fflush()  flushes all open output
       streams.
La fflush per lo standard input sapevo che non andava bene.. il comportamento è indefinito.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 21:28   #7
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Uh hai ragione lo stream è in input!

Due sviste in due giorni... no no, dovrò leggere meglio i messaggi prima di rispondere d'ora in poi...
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 21:28   #8
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da ..::DAVE::.. Guarda i messaggi
i caratteri inseriti da tastiera vanno tutti in stdin quindi con la getchar() vai a utilizzare lo stesso buffer della scanf.
OK, però non capisco: la getchar trova il carattere di a capo nel buffer ed esce dal ciclo, che è quello che ha lasciato la scanf precedente, se ho capito bene. E poi? Chi lo svuota il buffer? Sempre la getchar?
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 22:09   #9
dreadknight
Member
 
L'Avatar di dreadknight
 
Iscritto dal: Aug 2007
Messaggi: 50
Quote:
Originariamente inviato da Unrue Guarda i messaggi

So che mettendo il "\n" all'interno della scanf il problema dovrebbe risolversi. Ma non funziona.. Il programma, dopo aver inserito il nome, mi salta direttamente al numero civico.
prima dell'inserimento dati con le printf, aggiungi questa riga:
Codice:
fflush(stdin);
Inoltre ci sono degli errori:
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>




struct record_lista
  { char nome[20];
    char cognome[20];
    char indirizzo[20];
    int numero_civico;
    
  };

typedef struct record_lista persona;

int main(void){

  int dimension;
  int i;
 
  printf("Inserisci la dimensione: \n");
  scanf("\n%d",&dimension);
 

  persona*array_din=(persona*)malloc(sizeof(persona)*dimension);
  
  i=0;
  
  for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  
  printf("Inserisci il nome: \n");
  gets(array_din[i].nome);  /*è una stringa, non un intero*/
  
  printf("Inserisci il cognome: \n");
  gets(array_din[i].cognome);

  printf("Inserisci l'indirizzo: \n");
  gets(array_din[i].indirizzo);

   printf("Inserisci il numero civico: \n");
   scanf("\n%d",&array_din[i].indirizzo); /*qui invece è un intero, non una stringa*/
 
 
     
   }

   i=0;
   for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  printf("Nome: %s\n",array_din[i].nome); /*nella printf non si usa la & */
  printf("Cognome: %s\n",array_din[i].cognome);
  printf("Indirizzo: %s\n",array_din[i].indirizzo);
  printf("Numero civico: %d\n",array_din[i].numero_civico);
    
     
   }

free(array_dyn);

return 0;
  }

Ultima modifica di dreadknight : 09-05-2008 alle 22:31.
dreadknight è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 22:24   #10
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da dreadknight Guarda i messaggi
prima dell'inserimento dati con le printf, aggiungi questa riga:
Codice:
fflush(stdin);
No, leggi su, è contro gli standards, ha ragione. Otterresti un comportamento indefinito, è implementata "per funzionare" solo dal compilatore C della Microsoft. Al massimo può leggere fino alla fine o con scanf("%*s"); finché non riceve più nulla.
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 22:29   #11
..::DAVE::..
Senior Member
 
L'Avatar di ..::DAVE::..
 
Iscritto dal: Nov 2006
Città: Mantova
Messaggi: 468
Quote:
Originariamente inviato da Unrue Guarda i messaggi
OK, però non capisco: la getchar trova il carattere di a capo nel buffer ed esce dal ciclo, che è quello che ha lasciato la scanf precedente, se ho capito bene. E poi? Chi lo svuota il buffer? Sempre la getchar?
nessuno lo svuota dato che la getchar si prende l'invio della scanf e non lo riempie in altra maniera...
il buffer avrà sempre i dati di prima ma quello che da fastidio alle scanf è il \n
..::DAVE::.. è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2008, 22:32   #12
dreadknight
Member
 
L'Avatar di dreadknight
 
Iscritto dal: Aug 2007
Messaggi: 50
c'erano degli errori nel codice, penso di aver corretto tutto. Ora bisogna solo compilare e vedere se funziona
dreadknight è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:31   #13
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da dreadknight Guarda i messaggi
prima dell'inserimento dati con le printf, aggiungi questa riga:
Codice:
fflush(stdin);
Inoltre ci sono degli errori:
Codice:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>




struct record_lista
  { char nome[20];
    char cognome[20];
    char indirizzo[20];
    int numero_civico;
    
  };

typedef struct record_lista persona;

int main(void){

  int dimension;
  int i;
 
  printf("Inserisci la dimensione: \n");
  scanf("\n%d",&dimension);
 

  persona*array_din=(persona*)malloc(sizeof(persona)*dimension);
  
  i=0;
  
  for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  
  printf("Inserisci il nome: \n");
  gets(array_din[i].nome);  /*è una stringa, non un intero*/
  
  printf("Inserisci il cognome: \n");
  gets(array_din[i].cognome);

  printf("Inserisci l'indirizzo: \n");
  gets(array_din[i].indirizzo);

   printf("Inserisci il numero civico: \n");
   scanf("\n%d",&array_din[i].indirizzo); /*qui invece è un intero, non una stringa*/
 
 
     
   }

   i=0;
   for(i;i< dimension;i++) {
  printf("Entry numero: %d  \n", i+1); 
  printf("Nome: %s\n",array_din[i].nome); /*nella printf non si usa la & */
  printf("Cognome: %s\n",array_din[i].cognome);
  printf("Indirizzo: %s\n",array_din[i].indirizzo);
  printf("Numero civico: %d\n",array_din[i].numero_civico);
    
     
   }

free(array_dyn);

return 0;
  }
La gets è deprecata. Non capisco perché è un errore usare la fgets al posto della tua consigliata gets

Ultima modifica di Unrue : 10-05-2008 alle 12:34.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:36   #14
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da ..::DAVE::.. Guarda i messaggi
nessuno lo svuota dato che la getchar si prende l'invio della scanf e non lo riempie in altra maniera...
il buffer avrà sempre i dati di prima ma quello che da fastidio alle scanf è il \n
Ma se la getchar legge il '\n' senza toglierlo dal buffer, una eventuale scanf successiva non si ritrova con lo stesso problema?

Ultima modifica di Unrue : 10-05-2008 alle 12:39.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:44   #15
dreadknight
Member
 
L'Avatar di dreadknight
 
Iscritto dal: Aug 2007
Messaggi: 50
Quote:
Originariamente inviato da Unrue Guarda i messaggi
La gets è deprecata. Non capisco perché è un errore usare la fgets al posto della tua consigliata gets
ma hai letto le correzioni? di errori ce n'erano parecchi, se poi vuoi usare fgets fai pure
dreadknight è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:44   #16
..::DAVE::..
Senior Member
 
L'Avatar di ..::DAVE::..
 
Iscritto dal: Nov 2006
Città: Mantova
Messaggi: 468
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Ma se la getchar legge il '\n' senza toglierlo dal buffer, una eventuale scanf successiva non si ritrova con lo stesso problema?
leggendo lo 'passa' e poi legge dall'immissione successiva...
..::DAVE::.. è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:55   #17
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da dreadknight Guarda i messaggi
ma hai letto le correzioni? di errori ce n'erano parecchi, se poi vuoi usare fgets fai pure
Ora funziona tutto. Grazie a tutti
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 12:59   #18
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Quote:
Originariamente inviato da ..::DAVE::.. Guarda i messaggi
leggendo lo 'passa' e poi legge dall'immissione successiva...
Dunque, quindi la scanf legge la stringa immessa e si ferma al '\n', solo che non fa avanzare il puntatore del buffer alla posizione successiva, quindi la scanf dopo continua a leggerlo? Invece il getchar legge il '\n' ma avanza il puntatore. Credo sia così.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 10-05-2008, 14:49   #19
..::DAVE::..
Senior Member
 
L'Avatar di ..::DAVE::..
 
Iscritto dal: Nov 2006
Città: Mantova
Messaggi: 468
Quote:
Originariamente inviato da Unrue Guarda i messaggi
Dunque, quindi la scanf legge la stringa immessa e si ferma al '\n', solo che non fa avanzare il puntatore del buffer alla posizione successiva, quindi la scanf dopo continua a leggerlo? Invece il getchar legge il '\n' ma avanza il puntatore. Credo sia così.
esatto
..::DAVE::.. è offline   Rispondi citando il messaggio o parte di esso
Old 11-05-2008, 13:06   #20
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6790
Trallaltro, sempre una cosa che non ricordo legato a questo esempio: sia la printf che la scanf prendono in ingresso un puntatore a char. Come mai allora nella printf non ci va il & e nella scanf si, quando si passano i parametri?
Unrue è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Poste Italiane lancia un'Opas su TIM: la...
La crisi delle memorie potrebbe durare a...
Epic non ha alcuna intenzione di smetter...
MacBook Neo: la scommessa economica di A...
Addio elio-3? La scoperta cinese che pot...
OpenAI punta a 8.000 dipendenti entro il...
Democratici all'attacco di NVIDIA: l'acc...
Elon Musk ha annunciato TeraFab: fabbric...
Tutte le migliori offerte Amazon del wee...
Assassin's Creed: iniziate le riprese de...
TV 4K in super offerta: 75'' Mini-LED Hi...
iPad Air in offerta: 11'' con chip M3 a ...
Garmin Instinct 2X Solar Tactical a 259€...
Crimson Desert: Intel ha cercato di coll...
MacBook Air M4 da 899€ su Amazon, ma non...
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: 23:40.


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