| 
 | |||||||
| 
 | 
|  | 
|  | 
|  | Strumenti | 
|  26-06-2007, 10:44 | #1 | 
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | 
				
				[C] gcc e malloc: non ci posso credere!
			 
		allora, qui´ c´e´ il codice che NON funziona Codice: BYTE **ppVals = (BYTE**)malloc((nObjects - 1) * sizeof(BYTE*)); Codice: BYTE **ppVals; ppVals = (BYTE**)malloc((nObjects - 1) * sizeof(BYTE*));   Il bello e´ che dopo 2 ore di bestemmie, cercando l´errore altrove, un ragazzo non certo esperto, incuriosito, m´ha chiesto se serviva aiuto. Gli ho setto: grazie ma dovresti essere resperto di pointers e malloc. Comunque prova a vedere. La prima cosa che m´ha detto e´ stata: "prova a separare dichiarazione e assegnazione, magari il compilatore non capisce". E l´ho fatto solo per falo contento ... Ma sono sicuro di aver gia´ fatto dichiarazioni con assegnamento anche di doppi puntatori. Qualcuno mi sa spiegare ? grazie 
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | 
|   |   | 
|  26-06-2007, 10:48 | #2 | 
| Senior Member Iscritto dal: Apr 2000 Città: Roma 
					Messaggi: 15625
				 | 
		O un bug grossolano nel tuo gcc, o qualche errore nel tuo programma (tipo uno stack overflow) che solo casualmente ha effetti diversi nei due casi. Se compili le due situazioni abilitando l'ottimizzazione cambia qualcosa? 
				__________________ 0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12 | 
|   |   | 
|  26-06-2007, 10:58 | #3 | 
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | 
		
non so, adesso ci provo grazie
		 
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | 
|   |   | 
|  26-06-2007, 11:17 | #4 | 
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | 
		ecco appunto. Solo debuggando da problemi. Ottimizzando non potevo debuggare quindi ho solo lanciato e andava (-O1, -O2 e -O3). Poi ho provato anche con solo -g e funziona. Boh ? comunque ´sto debugger ogni giorno ne da una nuova  C´e´ anche da dire che sto debuggando un eseguibile che crea n threads e comunica con altri eseguibili che creano altri n threads e certi hanno dei timers per fare polling ... insomma, povero debugger  vabbe´, grazie   
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | 
|   |   | 
|  26-06-2007, 14:28 | #5 | 
| Utente sospeso Iscritto dal: Oct 2002 
					Messaggi: 2156
				 | 
		la prima è una definzione con inizializzazione e può essere scritta anche al di fuori di funzioni; la seconda è una definizione seguita da una inizializzazione ed è valida solo dentro funzioni. A parte questo entrambe devono funzionare, potrebbe essere un bachetto del tuo compilatore quando compila in debug (succede e non solo al gcc)   
				__________________ sign editata dallo staff | 
|   |   | 
|  26-06-2007, 14:40 | #6 | |
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | Quote: 
 Prima provo se va POI, se non va, debuggo. Altrimenti son piu´ le volte che non va per colpa del debugger ... 
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | |
|   |   | 
|  26-06-2007, 15:26 | #7 | 
| Bannato Iscritto dal: Feb 2005 Città: Roma 
					Messaggi: 7029
				 | 
		race condition   oppure... di' un po', ma il codice che hai postato è ESATTAMENTE quello del programma? cioè anche quando separi le istruzioni stanno messe precisamente come le hai scritte una dopo l'altra entrambe dentro una stessa funzione? | 
|   |   | 
|  26-06-2007, 15:27 | #8 | 
| Bannato Iscritto dal: Feb 2005 Città: Roma 
					Messaggi: 7029
				 | 
		aè! ma ora che ci guardo... tu stai usando una nomenclatura e dei tipi di Win32   ma stai usando MinGW? | 
|   |   | 
|  26-06-2007, 15:35 | #9 | 
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | 
		
si, esattamente. Perche´ ?
		 
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | 
|   |   | 
|  26-06-2007, 15:36 | #10 | |
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | Quote: 
 non ci vuol molto a fare #define BOOL unsigned char o typedef unsigned char BOOL;  comunque c´hai preso un po´ ... il tipo che ha iniziato il progetto (io sono entrato dopo) e´ un Windowista   
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | |
|   |   | 
|  26-06-2007, 17:27 | #11 | |
| Bannato Iscritto dal: Feb 2005 Città: Roma 
					Messaggi: 7029
				 | Quote: 
  e comunque si parlava del tipo BYTE, non BOOL   | |
|   |   | 
|  26-06-2007, 17:31 | #12 | 
| Bannato Iscritto dal: Feb 2005 Città: Roma 
					Messaggi: 7029
				 | 
		
 perché se nel codice funzionante avessi messo la dichiarazione della variabile fuori dalla funzione questa non sarebbe stata più allocata nello stack (e quindi non sarebbe più stata sovrascritta in maniera arbitraria dopo l'uscita della funzione) e quindi mi era venuto in mente che la utilizzassi al di fuori della funzione in qualche modo casinoso per fare riferimento alla memoria allocata con malloc. ma siccome il tipo è un bravo ragazzo windowsista sa bene che non bisogna mai utilizzare variabili finite fuori scope, ed in particolare che non bisogna mai ritornare puntatori a variabili locali    | 
|   |   | 
|  26-06-2007, 20:01 | #13 | |
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | Quote: 
  ho trovato il files defines.h ed ho copiato la parte sbagliata e comunque sia BYTE che BOOL sono stati definiti come unsigned char. Ma io non c'entro niente   
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | |
|   |   | 
|  26-06-2007, 20:12 | #14 | |
| Senior Member Iscritto dal: May 2006 Città: Wursteland 
					Messaggi: 1749
				 | Quote: 
  Anzi, pensa che all'inizio la variabile era un parametro di una funzione tipo funz( BYTE*** pppVar) e veniva passato un puntatore, quindi allocato, ma niente ... crashava lo stesso. E comunque il problema è risolto, non è colpa mia ma del debugger  Poi se tu vuoi aprire una guerra tra linuxomani e finestrari ... let's fight    
				__________________ Nintendo WIII 4d Turbo Intercooler - Sestium X 666 99,312 GHz - 6.984 Ram Σ(9999) MHz - HDD SATA 97e^(10) bytes 93³ rpm - ATI biberon X900z ∞Mb - Win Eight SP (1 > yours) 16 Valve | |
|   |   | 
|   | 
| Strumenti | |
| 
 | 
 | 
Tutti gli orari sono GMT +1. Ora sono le: 06:18.









 
		 
		 
		 
		









 
  
 



 
                        
                        










