|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
[C] Problema con funzione gets
Ciao a tutti! sono nuovo del forum, mi sono deciso ad iscrivermi perchè ho notato la diffusa competenza tra gli utenti
![]() Compilatore : Dev-C++ 4.9.9.2 S.O. : Windows XP su VirtualBox il problema è che, immesso il valore 1 per x, mi dovrebbe svolgere tutte le funzioni presenti nell'IF. In realtà mi fa creare il file (che so, prova.txt) ma non mi fa inserire il testo che deve comparire sul txt andandomi subito in system pause. Come mai? Se invece l'inserimento della stringa testo la metto fuori dallIF, me la prende... Codice:
scanf("%d",&x); if (x==1){ printf("Digita il nome del file da creare : ",nome_file); scanf("%s",nome_file); printf("Digita il testo da inserire nel file : "); gets(testo); fp = fopen(nome_file,"w"); fprintf(fp,"%s\n",testo); fclose(fp); } |
![]() |
![]() |
![]() |
#2 | |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Quote:
Molto probabilmente hai un buffer overrun proprio li. Io tra l'altro userei la fgets al posto della gets. |
|
![]() |
![]() |
![]() |
#3 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
ciao! la var testo la dichiaro come char : char testo [100]
|
![]() |
![]() |
![]() |
#4 | |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Quote:
Però come ti dicevo usa la fgets, la gets è deprecata e la fgets è sicura. Ultima modifica di airon : 22-04-2013 alle 13:43. |
|
![]() |
![]() |
![]() |
#5 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
si, inserisco il classico Hello World. Il mio problema deriva dal fatto che facendo scanf con %s come variabile testo, mi prendeva (ovviamente) solo Hello. World non me lo scriveva perchè c'è il carattere spazio di mezzo.
Mi potresti far vedere come si modifica con fgets? sto provando ma è una funzione che non ho mai usato ed ho problemi di sintassi...grazie in anticipo!! Ultima modifica di LucaST79 : 22-04-2013 alle 13:57. |
![]() |
![]() |
![]() |
#6 |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
E' molto semplice:
fgets (dove_vuoi_memorizzzare_i_caratteri, caratteri_massimi, da_dove prendere_i_caratteri); Quindi nel tuo caso: fgets(testo, 100, stdin); stdin sta per standard input ovvero la tastiera. POtresti ad esempio se apri un file leggere riga per riga e al posto di stidin mettere il puntatore al file. Quindi la fgets leggerebbe riga per riga al massimo 100 caratteri. Spero di essere stato chiaro. Prova e facci sapere. Ciaoo |
![]() |
![]() |
![]() |
#7 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
provato...mi da lo stesso identico skip e mi va in system pause senza farmi inserire alcun carattere:
Codice:
int x; FILE *fp; char testo[100],nome_file[20]; ... scanf("%d",&x); if (x==1){printf("Digita il nome del file da creare : ",nome_file); scanf("%s",nome_file); printf("Digita il testo da inserire nel file : "); fgets(testo,100,stdin); fp = fopen(nome_file,"w"); fprintf(fp,"%s\n",testo); fclose(fp); } |
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Metti un po' di codice di debug:
Stampa nome file, stringa presa in input, fp, e il risultato della printf. COsi puoi capire dove è il problema. |
![]() |
![]() |
![]() |
#9 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
già fatto tutto, il nome del file che inserisco me lo legge con scanf. Quindi vado a printarlo e me l'ha preso...anche perchè me lo crea proprio materialmente.
E' il passo successivo che crea errori. Mi dice di digitare il testo da inserire ed invece che darmi il cursore per scrivere e per memorizzare sulla variabile char "testo" mi va SUBITO in system pause (per intenderci mi scrive "Premere un pulsante per continuare"). La cosa strana è che se elimino lo scanf del nome_file mi funziona tutto... |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Il problema sta proprio nella prima scanf che si porta dietro il '\n' quindi salta l'istruzione successiva.
Sicenramente non so perchè succeda, forse un problema di buffering dello stdin. Per ovviare a ciò usa la fgets al posto della prima scanf e converti la stringa in numero se devi fare x==1 usando atoi ad esempio. numero = atoi(stringa); Così dovrebbe andare ![]() |
![]() |
![]() |
![]() |
#11 |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Io son riuscito
![]() Ultima modifica di airon : 22-04-2013 alle 14:36. |
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Feb 2004
Città: milano
Messaggi: 2148
|
Codice:
#include<stdio.h> int main() { char scelta[10]; FILE *fp; char testo[100], nome_file[20]; int x; fgets(scelta,10, stdin); x = atoi(scelta); if (x==1){ printf("Digita il nome del file da creare : ",nome_file); fgets(nome_file,20,stdin); printf("Digita il testo da inserire nel file : "); fgets(testo,100,stdin); fp = fopen(nome_file,"w"); fprintf(fp,"%s\n",testo); fclose(fp); } return 0; } |
![]() |
![]() |
![]() |
#13 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
ho provato ad eseguire il testo che mi hai postato ma non crea il file...
|
![]() |
![]() |
![]() |
#14 |
Junior Member
Iscritto dal: Apr 2013
Messaggi: 13
|
edit : se inserisco il primo fgets (quello che memorizza la scelta) e gli altri 2 li sostituisco con gets mi gira...
se ripeto fgets per scelta, nome_file e testo Windows mi da errore...provato su debian invece gira benissimo.. grazie mille!!! ed aggiungo : anche inizializzando la variabile scelta come int invece che come char funziona benone. Penso che andando a prendere un imput da tastiera sia più importante la conversione da carattere (da keyboard appunto) piuttosto che il tipo di variabile impostato per scelta. Ultima modifica di LucaST79 : 22-04-2013 alle 15:35. |
![]() |
![]() |
![]() |
#15 |
Senior Member
Iscritto dal: Jul 2003
Città: Alessandria
Messaggi: 10167
|
Consiglio: abbandona Dev-C++ . Dicono che dia errori di compilazione e che alcuni errori di sintassi e/o warning non vengano segnalati
EDIT: Code::Blocks è un'eccellente alternativa free
__________________
Dell XPS 13 (9350) :: i5-2500K - HD6870 - AsRock Z68 Pro3 - Corsair Vengeance 8GB (4x2) DDR3 :: Samsung Galaxy S4 GT-i9505
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 06:17.