Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-12-2005, 16:53   #1
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
[C] File con pezzo di codice che da errore

Questo codice mi causa un errore e l'uscita dal programma:


premetto che nomeLetto e punteggioLetto sono dichiarati globali al momento così:

int punteggioLetto[5];
char nomeLetto[5][20];

[code]
void aggiorna_classifica(char nome[20], char nome2[20], int *punteggioP1, int *punteggioP2)
{
int i=0;
int ins=-1;//continene la posizione in cui inserire il nuovo punteggio

datafile=fopen("Classifica.txt", "r");
if(datafile==NULL)
{
printf("Non è stato possibile leggere il file!");
}
for(i=0;i<4;i++)
fscanf(datafile,"%s%d", nomeLetto[i], punteggioLetto[i]);

fclose(datafile);


datafile=fopen("Classifica.txt", "w");

for(i=0;i<4;i++)
{
fprintf(datafile,"%s\n", nomeLetto[i]);
fprintf(datafile,"%d\n", punteggioLetto[i]);
}
}
[\CODE]

Ho tagliato una buona parte della funzione in cui non utilizzavo i file ma facevo solo calcoli e assegnazioni sulle variabili.
Sono quasi certo che l'errore lo causi l'apertura o la scrittura su file.
Il file esiste ed è nella cartella del programma.
Se il contenuto del file lo cancello a mano il programma non da errore, se nel file c'è scritto qualcosa es:

Ivan
30
Gino
50
Billy
45

il programma da errore ed esce.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 00:14   #2
Torav
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 558
potrei tranquillamente sbagliarmi data la mia non ottima (per usare un eufemismo ) conoscenza del c, ma se non sbaglio fscanf richiede l'indirizzo della/e variabile/i in cui devi scrivere i valori che leggi dal file (ed è lo stesso anche per scanf)
Torav è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 00:54   #3
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Si è vero però in questo caso sono vettori che vengono passati automaticamente come indirizzo del primo elemento quindi non penso sia quello il motivo.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 09:27   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Penso che Torav si riferisse alla
fscanf(datafile,"%s%d", nomeLetto[i], punteggioLetto[i]);

Essendo
int punteggioLetto[5];
dovrai mettere l'ampersand (&) davanti alla variabile in questione, cosa che non dovrai fare per nomeLetto.

Alcuni suggerimenti:
- Quando apri un file (sia in lettura sia in scrittura), controlla SEMPRE l'esito;
- Nel primo caso hai controllato l'esito in maniera non sufficiente: infatti se datafile==NULL, il programma proseguira' e terminera' con errore, in quanto cercherai da leggere da un descrittore di file non valido;
- L'istruzione
fscanf(datafile,"%s%d", nomeLetto[i], &punteggioLetto[i]);
e' sufficientemente pericolosa da lasciarti giorni a cercare dov'e' il problema. Visto il file che vai ad aprire, non dovrebbero esserci problemi, ma ti consiglio di fare attenzione;
- Curiosita': hai dichiarato degli array di 5 elementi e ne usi solo i primi 4. E' esattamente quello che volevi fare o una svista?
- Altra curiosita': la dichiarazione
void aggiorna_classifica(char nome[20], char nome2[20], int *punteggioP1, int *punteggioP2)
potrebbe darti problemi sui nuovi compilatori. Lasciando stare il fatto di dichiarare in formato compatibile ANSI e K&R (obsoleto), forse e' meglio dichiarare
void aggiorna_classifica(char *nome, char *nome2, int *punteggioP1, int *punteggioP2)
in quanto la definizione precedente introduce un nuovo tipo di dato. Alcuni compilatori piuttosto pedanti ti darebbero errore. Cosi' sei piu' portabile.

Spero di esserti stato di aiuto

High Flying
Sottovento
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 09:42   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da -Ivan-
Codice:
fscanf(datafile,"%s%d", nomeLetto[i], punteggioLetto[i]);
Ciao, il problema è proprio nella chiamata a fscanf.
Allora ... nomeLetto è un array bidimensionale di char. Questo vuol dire che quando fai nomeLetto[i], ottieni un indirizzo perché è equivalente a &nomeLetto[i][0]. Invece punteggioLetto è un array di int e quando fai punteggioLetto[i] ottieni il valore a quel indice e non un indirizzo. Quindi dovresti mettere &punteggioLetto[i] nella fscanf.

Inoltre ti segnalo un'altra cosa: nei due cicli for fai partire i da 0 ma testi i<4 così però non gestisci il quinto elemento!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 13:09   #6
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Grazie a tutti, ci sto lavorando adesso.
Un errore me lo dava perchè forse inserivo i dati manualmente nel file in maniera non corretta (non come se li aspettava il programma anche se ero convinto di si).
Se faccio fare tutto al programma funziona anche se mi scrive delle cose assurde sul file come simboli e credo anche un indirizzo di memoria.
Adesso mi ci metto e spero di sistemare tutto.
Grazie ancora.



Per andbin: ora non uso tutti gli elementi dei vettori perchè non so quanti punteggi memorizzare in classifica, quando avrò deciso modificherò le variabili.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
Old 15-12-2005, 13:53   #7
-Ivan-
Senior Member
 
L'Avatar di -Ivan-
 
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1846
Mi sa che sto peggiorando la situazione, il risultato nel file di testo dopo 2 partite è il seguente:
5
45
0
0
Pÿ?
45

0
Pÿ?
23189240

lasciando perdere il fatto che dovrebbe essere formattato nel modo seguente (ma può non esserlo per errori nel corso della funzione):
nome
punteggio
nome
punteggio
nome
punteggio
nome
punteggio
nome
punteggio

mi sembra strano che scriva degli inidirizzi e dei simboli come quelli che ci sono.

Codice:
void aggiorna_classifica(char nome[20], char nome2[20], int *punteggioP1, int *punteggioP2, int *ris)
{     
     int i=0;
     int ins=-1;//continene la posizione in cui inserire il nuovo punteggio
     
     datafile=fopen("Classifica.txt", "r");
     if(datafile==NULL)
     {
          printf("Non è stato possibile leggere il file!");
     }
     else
     {
          for(i=0;i<5;i++)
               fscanf(datafile,"%s%d", nomeLetto[i], &punteggioLetto[i]);
     }
     fclose(datafile);
     //cerca se il punteggio della partita attuale è maggiore di uno di quelli in classifica
     if(*ris==1)
     {
        if(*punteggioP1>punteggioLetto[0]) ins=0;
     }
     if(*ris==2)
     {
        if(*punteggioP2>punteggioLetto[0]) ins=0;
     }
     for(i=0;i<4;i++)
     {
          if(*ris==1)
          {
               if(*punteggioP1<punteggioLetto[i] && *punteggioP1>punteggioLetto[i+1])
                    ins=i;          
          }
          if(*ris==2)
          {
               if(*punteggioP2<punteggioLetto[i] && *punteggioP2>punteggioLetto[i+1])
                    ins=i;          
          }
     }
     //trasla gli elementi della classifica per immettere poi quello nuovo se necessario
     if(ins!=-1)
     {
          i=4;
          for(;i==ins;i--)
               punteggioLetto[i]=punteggioLetto[i-1];
          
          if(*ris==1)
          {
               punteggioLetto[ins]=*punteggioP1;
               strcpy(nomeLetto[ins], nome);
          }
          if(*ris==2)
          {
               punteggioLetto[ins]=*punteggioP2;
               if(ins==1)
               strcpy(nomeLetto[ins], nome2);
          }
     }
     //scrive sul file la nuova classifica
     datafile=fopen("Classifica.txt", "w");
     
          for(i=0;i<5;i++)
          {
               fprintf(datafile,"%s\n", nomeLetto[i]);
               fprintf(datafile,"%d\n", punteggioLetto[i]);
          }
}
forse l'errore è nella copia tra stringhe?

Il codice per calcolare la posizione in cui scrivere l'ho buttato giù velocemente, probabilmente non è corretto ma quello che mi interessa ora è che i dati vengano letti e scritti per quello che sono.
-Ivan- è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Gmail cambia le regole: stop a Gmailify ...
Lutto nel mondo scientifico: si è spento...
Toyota sviluppa Fluorite, un motore open...
Google lancia l'allarme: un miliardo di ...
Secondo NVIDIA, i 660 miliardi di dollar...
Qualcomm punta sulla flessibilità...
Amazon sconta schede video, CPU e access...
Halo: Campaign Evolved, l'uscita del rem...
La rete elettrica europea sta limitando ...
Apple Magic Keyboard per iPad Pro 11'' i...
BYD punta a nuove tecnologie: batterie a...
Windows 11 porta il Bluetooth multi-disp...
iPhone 17e e non solo: Gurman svela le c...
Arrestato per omicidio, in lacrime ai po...
Vexilar, scopa elettrica da 65000Pa, 4,9...
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: 14:36.


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