Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei
HUAWEI WiFi Mesh X3 Pro Suite è probabilmente il router mesh più fotogenico che si possa acquistare oggi in Italia, ma dietro il guscio in acrilico trasparente e le luci LED dinamiche c'è una macchina tecnica costruita attorno allo standard Wi-Fi 7, con velocità teoriche Dual-Band fino a 3,6 Gbps e una copertura fino a 120 m² una volta abbinato il router principale all'extender incluso nel kit
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte
Abbiamo provato le nuove CPU Intel Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: più core e ottimizzazioni al funzionamento interno migliorano le prestazioni, anche in virtù di prezzi annunciati interessanti. A questo si aggiungono nuove ottimizzazioni software. Purtroppo, a fronte di prestazioni di calcolo elevate, il quadro rimane incerto nel gaming, dove l'andamento rimane altalenante. Infine, rimane il problema della piattaforma a fine vita.
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
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: 6806
[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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   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: 6806
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 è online   Rispondi citando il messaggio o parte di esso
 Rispondi


Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
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...
Lo smartphone XIAOMI 17 12/512GB con ott...
iPhone, iPad e Mac si aggiornano: le nov...
MOUSE: P.I. For Hire si prepara al debut...
Razer Viper V4 Pro: più leggero, ...
Windows 95 e l'anarchia degli installer:...
Gli smartphone sotto i 260€ in offerta s...
BAIC accelera sul futuro delle auto elet...
Wine 11 porta NTSYNC nel kernel mainline...
Huawei XMAGE Awards 2026: al via la deci...
Ayaneo non ce la fa: la crisi di RAM e S...
Roborock F25 Ultra è la vera novi...
Dopo Bluepoint, Sony chiude un altro stu...
Windows e il caos delle interfacce: l'ex...
HP lancia i nuovi HyperX OMEN MAX 45L e ...
Amazon compra Fauna Robotics: il futuro ...
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: 11:58.


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