Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED i per professionisti dell'immagine
ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED i per professionisti dell'immagine
Un monitor veramente completo, per funzionalità e prestazioni. La presenza di un colorimetro integrato consente di agevolare le operazioni di calibrazione, anche per il mantenimento periodico delle prestazioni
HUAWEI WATCH FIT 3: lo smartwatch che ridefinisce design e fitness! Recensione
HUAWEI WATCH FIT 3: lo smartwatch che ridefinisce design e fitness! Recensione
Huawei è capace di sorprendere ancora e quest’anno lo fa con questo nuovo smartwatch WATCH FIT 3 che coniuga un design elegante e moderno con funzionalità di prim’ordine. Un mix tra smartwatch e fitness tracker con il coach animato incorporato.  
HONOR 200 Lite, lo smartphone economico per ritratti, selfie, e non solo. La recensione
HONOR 200 Lite, lo smartphone economico per ritratti, selfie, e non solo. La recensione
HONOR 200 Lite si presenta come uno smartphone completo e versatile a un prezzo molto competitivo. Caratteristiche interessanti sono il generoso display AMOLED da 2000 nits e la fotocamera principale da 108MP con tre lunghezze focali simulate per i ritratti. A coronare il pacchetto un'esperienza software completa grazie a MagicOS 8.0 e, in questo momento, una promozione lancio che permette di risparmiare 40€ sul listino ufficiale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-08-2006, 12:37   #1
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
[c] files[a] = *buffer; xké nn va????

if ((f = fopen ("files.txt", "r")) == NULL)
return 0; /* Errore */

while(fgets (buffer, sizeof (buffer), f)!=NULL)
{
if(( p = strchr(buffer,'\n'))!=NULL)
*p='\0';

a++;

files[a] = *buffer;

printf("%s",files[a]);


}

pero nn funziona!!! come mai??? nel file files.txt cé scritto:

casa
lavoro

non é la prima volta ke mi imbatto in questo problema: cioé d assegnare all'array una stringa con un puntatore....sicuro é una cagata...ma nn capisco...
$te è offline   Rispondi citando il messaggio o parte di esso
Old 26-08-2006, 14:08   #2
Barbalbero
Registered User
 
Iscritto dal: Aug 2006
Messaggi: 305
In che senso non funziona? quali sono i sintomi che ti portano ad una tale conclusione?
Barbalbero è offline   Rispondi citando il messaggio o parte di esso
Old 26-08-2006, 14:15   #3
Barbalbero
Registered User
 
Iscritto dal: Aug 2006
Messaggi: 305
Inoltre avrei bisogno di conoscere le dichiarazioni di
p
files
buffer
potrebbero essere sottintese, lo so...ma magari l'errore è lì...
Barbalbero è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2006, 22:26   #4
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
char *p, buffer[100],files[100];

il compilatore nn mi da errrori (uso devc) ma qnd avvio il programmino si blocca...e si kiude per errore
$te è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2006, 22:42   #5
wisher
Senior Member
 
L'Avatar di wisher
 
Iscritto dal: Aug 2005
Messaggi: 2755
dichiara p non come puntatore ma come array di char.
In questo modo allochi memoria non solo per il puntatore ma per tutta la stringa
__________________
wisher è offline   Rispondi citando il messaggio o parte di esso
Old 27-08-2006, 23:50   #6
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
ma dici ke é questo il problema? xké p deve essere un puntatore per poter fare:

if(( p = strchr(buffer,'\n'))!=NULL)

*p='\0';

xké se no mi dice ke cl un errore di compatibilità
$te è offline   Rispondi citando il messaggio o parte di esso
Old 28-08-2006, 07:59   #7
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
La variabile p deve essere un puntatore e su questo non ci sono dubbi!

Poi comunque non è molto chiaro cosa vuole fare $te. Lui dice che ha dichiarato:
char *p, buffer[100],files[100];
Sui primi 2 ok, non ci sono dubbi, il terzo (files) .... dipende da cosa vuole fare $te.

Si vuole ottenere che files contenga una copia del contenuto di buffer??? Oppure si vuole che ci sia un array di puntatori tale che files[0] punti a "casa" e files[1] punti a "lavoro", ecc... per le altre eventuali righe???

Il problema è tutto lì: capire cosa si vuole ottenere!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 28-08-2006, 13:05   #8
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
grande!!"hai capito!!! é proprio quello.....files[0] punterà a casa e files[1] a lavoro!!! hehe....problema mio a spiegarmi allora,scusate
$te è offline   Rispondi citando il messaggio o parte di esso
Old 28-08-2006, 13:29   #9
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da $te
é proprio quello.....files[0] punterà a casa e files[1] a lavoro!!!
Allora il tuo codice non va bene.
Di buffer (quello che usi per la fgets) ne hai 1 solo e viene sovrascritto ad ogni lettura di riga (ovviamente).

Quindi per prima cosa dichiari, per esempio:
char *linee[20];

Questo è un array di 20 puntatori. Ognuno di questi 20 puntatori può puntare ad una stringa.

Poi, dopo che hai letto la riga (e tolto quel rompiscatole di \n), devi calcolare la lunghezza della riga (usa strlen), poi devi allocare della memoria (usa malloc) in modo da avere una area di memoria dove copiare la stringa.
Nota che l'area di memoria deve essere lunga strlen(riga)+1, perché c'è anche il carattere nullo.
A quel punto assegni a linee[i] il puntatore all'area allocata, dopo aver ovviamente copiato la stringa nell'area.

Tutto chiaro??
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 08:18   #10
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
allora...io o da quel che ho capito ho fatto cosi:

while(fgets (buffer, sizeof (buffer), f)!=NULL)
{
if((p = strchr(buffer,'\n'))!=NULL)
*p='\0';

len = strlen (buffer);

linee[a] = malloc(len + 1);

linee[a] = buffer;

a++;

}

il problema che in linee[0] e linee[1] cé la stringa lavoro,come mai? dovrebbe invece essere linee[0] = casa, lenee[1] = lavoro, e invece viene sovrascritto sulla prima,come mai? forse nn ho capito le ultime cose ke mi hai detto...
$te è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 08:33   #11
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da $te
linee[a] = buffer;
Noo! così copi solo il puntatore al buffer (la malloc quindi così non servirebbe a niente).

Devi fare:
strcpy (linee[a], buffer);
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 09:34   #12
Barbalbero
Registered User
 
Iscritto dal: Aug 2006
Messaggi: 305
Un array altro non è che il puntatore alla prima cella di una serie allocata.
...mi pare che tutte le operazioni che fai su *p le puoi fare anche su p[]


...comunque in questo caso non ne vedo l'utilità

Ultima modifica di Barbalbero : 29-08-2006 alle 09:43.
Barbalbero è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 09:49   #13
Marco Giunio Silano
Senior Member
 
L'Avatar di Marco Giunio Silano
 
Iscritto dal: Jun 2006
Città: Inverno: Novgorod. Estate: Haifa
Messaggi: 875
Quote:
Originariamente inviato da Barbalbero
Un array altro non è che il puntatore alla prima cella di una serie allocata.
...mi pare che tutte le operazioni che fai su *p le puoi fare anche su p[]


...comunque in questo caso non ne vedo l'utilità
Sì, ma

linee[a] = buffer
linee[a] = buffer[0] <-> linee[a] = *buffer

sono un po' differenti

e poi, se ho capito bene, lui vuole copiare la stringa da un'altra parte, non avere il collegamento all'indirizzo della stringa sorgente. Quindi deve fare come dice Andbin
__________________
Hosti non solum dandam esse viam ad fugiendum, sed etiam muniendam / Ceterum censeo Carthaginem esse delendam / Et facere et pati fortia romanum est / Nemo Romanorum pacis mentionem habere dignatus est / Roma locuta, causa finita
Milla

Ultima modifica di Marco Giunio Silano : 29-08-2006 alle 09:52.
Marco Giunio Silano è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 09:53   #14
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Marco Giunio Silano
linee[a] = buffer
Questo sarebbe tecnicamente ok (un puntatore assegnato ad una variabile puntatore).
Ma non è quello che serve a $te.

Quote:
Originariamente inviato da Marco Giunio Silano
linee[a] = buffer[0] <-> linee[a] = *buffer
Queste non vanno bene (darebbero warning): buffer[0] oppure *buffer è 1 carattere, che quindi non è assegnabile ad una variabile puntatore.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)

Ultima modifica di andbin : 29-08-2006 alle 09:56.
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 09:57   #15
Barbalbero
Registered User
 
Iscritto dal: Aug 2006
Messaggi: 305
Quote:
Originariamente inviato da Marco Giunio Silano
Sì, ma

linee[a] = buffer
linee[a] = buffer[0] <-> linee[a] = *buffer

sono un po' differenti

e poi, se ho capito bene, lui vuole copiare la stringa da un'altra parte, non avere il collegamento all'indirizzo della stringa sorgente. Quindi deve fare come dice Andbin
Ovviamente devi capire cosa stai facendo e sapere quello che dici...

io intendo che puoi fare così:
Codice:
char *p;
char array[20];
...
//una volta allocato lo spazio per p
array[a]=p[a];
Quello che dici tu non c'entra molto...
Inoltre non ho detto che in questo caso va usato. Ho solamente discusso su questo punto:

Quote:
La variabile p deve essere un puntatore e su questo non ci sono dubbi!
Barbalbero è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 09:59   #16
Marco Giunio Silano
Senior Member
 
L'Avatar di Marco Giunio Silano
 
Iscritto dal: Jun 2006
Città: Inverno: Novgorod. Estate: Haifa
Messaggi: 875
Quote:
Originariamente inviato da andbin
Questo sarebbe tecnicamente ok (un puntatore assegnato ad una variabile puntatore).
Ma non è quello che serve a $te.

Queste non vanno bene (darebbero warning): buffer[0] oppure *buffer è 1 carattere, che quindi non è assegnabile ad una variabile puntatore.
ho letto solo gli ultimi due post dando per scontato che linee fosse un buffer di buffer (linee[...][...]) e che volesse copiare li buffer e non l'indirizzo di buffer, cosa che non ho codificato da nessuna parte, infatti avevo specificato: "e poi, se ho capito bene, lui vuole copiare la stringa da un'altra parte, non avere il collegamento all'indirizzo della stringa sorgente. Quindi deve fare come dice Andbin"
__________________
Hosti non solum dandam esse viam ad fugiendum, sed etiam muniendam / Ceterum censeo Carthaginem esse delendam / Et facere et pati fortia romanum est / Nemo Romanorum pacis mentionem habere dignatus est / Roma locuta, causa finita
Milla
Marco Giunio Silano è offline   Rispondi citando il messaggio o parte di esso
Old 29-08-2006, 10:01   #17
Marco Giunio Silano
Senior Member
 
L'Avatar di Marco Giunio Silano
 
Iscritto dal: Jun 2006
Città: Inverno: Novgorod. Estate: Haifa
Messaggi: 875
Quote:
Originariamente inviato da Barbalbero
Ovviamente devi capire cosa stai facendo e sapere quello che dici...

io intendo che puoi fare così:
Codice:
char *p;
char array[20];
...
//una volta allocato lo spazio per p
array[a]=p[a];
Quello che dici tu non c'entra molto...
Inoltre non ho detto che in questo caso va usato. Ho solamente discusso su questo punto:
Avete ragione, ho letto due post e mi sono intromesso senza consocere la questione... facendo confusione...
__________________
Hosti non solum dandam esse viam ad fugiendum, sed etiam muniendam / Ceterum censeo Carthaginem esse delendam / Et facere et pati fortia romanum est / Nemo Romanorum pacis mentionem habere dignatus est / Roma locuta, causa finita
Milla
Marco Giunio Silano è offline   Rispondi citando il messaggio o parte di esso
Old 30-08-2006, 10:34   #18
$te
Senior Member
 
L'Avatar di $te
 
Iscritto dal: Aug 2006
Messaggi: 1257
cmq ho risolto il problema grazie ad andbin,grazie!!!
$te è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED i per professionisti dell'immagine ASUS ProArt PA32UCXR: 4K, Quantum Dot e Mini-LED...
HUAWEI WATCH FIT 3: lo smartwatch che ridefinisce design e fitness! Recensione HUAWEI WATCH FIT 3: lo smartwatch che ridefinisc...
HONOR 200 Lite, lo smartphone economico per ritratti, selfie, e non solo. La recensione HONOR 200 Lite, lo smartphone economico per ritr...
MG4, due settimane al volante dell'elettrica popolare: pregi, difetti e autonomia MG4, due settimane al volante dell'elettrica pop...
Tre giorni in Finlandia con OnePlus Watch 2 Nordic Blue. La nostra prova a temperature estreme Tre giorni in Finlandia con OnePlus Watch 2 Nord...
Intel bacchetta, di nuovo, i produttori ...
La missione cinese Chang'e-6 è en...
Boeing CST-100 Starliner: il lancio dell...
Un'altra GPU cinese raggiunge la produzi...
iPad Air non è più il tabl...
Minisforum AtomMan X7 Ti: il Mini PC da ...
iPad Pro: i nuovi modelli hanno tantissi...
Ecco come Cubbit DS3 ha permesso a Cloud...
Ring presenta Pan-Tilt Indoor Camera, la...
Apple elimina iPad 9 dalla gamma, ma ade...
Tante novità per ho.mobile: raddo...
ASUS svelerà il suo primo noteboo...
Indovinate qual è la novità...
Non solo Seagate Barracuda 8TB a 135€: p...
Niente adesivi Apple nelle confezioni de...
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: 16:03.


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