Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-09-2007, 21:17   #1
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
[C]la free() a runtime dà "invalid next size"..

in seguito a delle free su puntatori a stringhe,quando mando il programma in esecuzione viene fuori questo errore

*** glibc detected *** free(): invalid next size (fast): 0x0804d070 ***

non riesco a trovare l'errore,nel codice ho visto dove si genera ma non so come poter rimediare anche perchè non ne conosco il significato...

..suggerimenti??

grazie mille
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2007, 22:22   #2
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
la cosa strana è che questa free è dentro uno switch dove ogni volta viene controllato l'input,eseguiti task,riazzerate le variabili e liberata la memoria per la richiesta del task successivo:

alla prima volta la free non dà problemi

la seconda volta,dopo aver eseguito le stesse cose sotto lo stesso caso dello switch,sul medesimo puntatore la free stampa su schermo l'errore...

sto navigando in rete+leggendo la teoria ma questi errori non sono mai trattati

santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 11-09-2007, 17:32   #3
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
while(1){

/*5-->entrata nel ciclo di ricezione comandi dal client*/
printf("in attesa della prossima richiesta su %s....\n",dir_richieste);


receive(&secondo_mess,fd_richieste);


printf("secondo mess = %s;\n",secondo_mess);

char * pEnd;
int j = 0;
int caratterimat = 0;
char * request;
char * nomemat1;
char * nomemat2;
char * nomemat3;
char * operando;
char * esito;

//uso la funzione strtol per estrarre il codice operativo del comando
cod_op = strtol(secondo_mess,&pEnd,10);
printf("codice operativo = %d\n",cod_op);


//entro nell'esecuzione dei comandi
switch(cod_op){


case 0:

lung_secondo = strlen(secondo_mess);
if((request = (char *)calloc(lung_secondo,sizeof(char)))== NULL){
printf("malloc per inizializzazione comando fallita,terminazione client");
exit(1);
}

while(j != lung_secondo){
request[j]=secondo_mess[j];
j++;
}
request[j]='\0';
printf("comando = %s;\n",request);


//alloco lo spazio per il nome della matrice
if((nomemat1 = (char *)malloc(sizeof(char)*MAX_NOME))== NULL){
printf("malloc per inizializzazione comando fallita,terminazione client");
exit(1);
}
j=0;
while(request[j+1] != '_'){
printf("%c\n",request[j+1]);
nomemat1[j]=request[j+1];
j++;
}
nomemat1[j]= '\0';
caratterimat = strtol(&request[j+2],&pEnd,10);

printf("nomemat = %s,datimat = %s,numero caratteri = %d,dati matrice = %s\n",nomemat1,request,caratterimat,pEnd);

//controlla se è già stata inizializzata dall'insieme delle matrici,nel caso restiuisce un errore
int check;
if((check = checkname(insiememat,nomemat1,NOT_DEL))!=-1){
if((esito = (char *)malloc(sizeof(char)*SIZE_MAT_ERROR+1)) == NULL){
printf("malloc per inizializzazione comando fallita,terminazione client");
exit(1);
}
esito = "Error:unable to change matrix size";
send(esito,fd_client);
}

//inizializza la matrice e la inserisce nell'insieme delle matrici
else{
add_in_matset(insiememat,mat_create,nomemat1,pEnd);
esito = "ok";
send(esito,fd_client);
}


printf("secondomess= %s\n",secondo_mess);
free(secondo_mess);
printf("request= %s\n",request);
free(request);

break;
santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2007, 01:38   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Assegnazioni come questa:

esito = "Error:unable to change matrix size";

non vanno bene...perdi il puntatore allo spazio allocato per esito.
Usa la funzione strcpy per inserire del testo in una stringa per cui hai già allocato lo spazio.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 12-09-2007, 10:42   #5
santaclause83
Member
 
Iscritto dal: Mar 2006
Messaggi: 131
corretto l'errore con esito..però l'errore persiste

nello switch case per ora sto testando solo il caso 0,e mando input su input che riguardano solo quel caso.

pare che capiti dopo l'ultima free del caso zero,quella su "request",poco sopra l'inizio del caso 1.

la cosa strana è che il messaggio di errore sulla free si presenta solo ed esclusivamente alla seconda volta che mando l'input,se non si blocca la seconda volta,va avanti senza problemi(chiaramente non so esattamente fino a quando,l'avrò fatto altre 10 volte e ho visto che non si bloccava mai)

santaclause83 è offline   Rispondi citando il messaggio o parte di esso
Old 13-09-2007, 20:05   #6
eliano
Senior Member
 
L'Avatar di eliano
 
Iscritto dal: Mar 2002
Città: Capua (CE)
Messaggi: 317
Codice:
receive(&secondo_mess,fd_richieste);
Perché mandi alla receive l'indirizzo del puntatore al buffer e non il puntatore stesso?
__________________
Se pensi di sapere, sappi che non sai di non saperlo!
Le mie statistiche - "real man uses Duron!"
Ho fatto affari con: schumyFast, navale, The_Nameless_One, Sonic80, diamante.picci, Downset88, ilviandante, tecno789
eliano è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
FTX, la Corte d'Appello conferma la cond...
OnePlus anticipa l'arrivo di nuove cuffi...
YouTube da record con 2,7 miliardi di ut...
Samsung Galaxy Watch Ultra 2, l'autonomi...
Deezer ha rilasciato un tool gratuito pe...
AMD Ryzen 9 7950X3D danneggiato: approva...
I Mac con chip Apple Silicon hanno meno ...
Scandalo nel Regno Unito: agente sotto i...
TOP 15 offerte Amazon del weekend: 10 tu...
DJI Neo Fly More Combo a 245€: il mini d...
JBL Live Beam 3 a 129€ invece di 199€ su...
L'FBI ha costruito una città segr...
AMD usa il MacBook Neo come bersaglio in...
Intel prepara 'Raptor Lake Next'? Nel 20...
Una telefonata del CEO di Amazon dietro ...
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: 21:33.


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