Italian community of Lazarus and Free Pascal

Programmazione => Generale => Topic aperto da: Maverich - Aprile 11, 2012, 09:58:26 am

Titolo: Form / Child e TButton
Inserito da: Maverich - Aprile 11, 2012, 09:58:26 am
Ho creato un semplie test Form / Child creato a run time, e mi accorgo che :
- se chiudo il Child con un TButton collegato ad una TAction, dopo il FreeAndNil solleva eccezione.
- se invece utilizzo un TSpeedButton collegato alla stessa TAction , non viene sollevata alcuna eccezione.

Provate l'esempio con Button e cliccando su Button e TSpeedButton per chiudere il child, vedrete la differenza di comportamento.
Funziona anche avviato il child da Button e chiuso con TSpeedButton.

Certo portrebbe essere un problema di IDE, ma dubito, avviene anche nell'eseguibile.
Titolo: Re:Form / Child e TButton
Inserito da: xinyiman - Aprile 11, 2012, 11:52:47 am
Non esiste la unt_Base nel tuo allegato! Quindi non compila!
Titolo: Re:Form / Child e TButton
Inserito da: Maverich - Aprile 11, 2012, 04:38:10 pm
sorry, provvedo.
Titolo: Re:Form / Child e TButton
Inserito da: xinyiman - Aprile 12, 2012, 10:12:41 am
Ho provato e confermo l'anomalia. Ora provo a vedere se capisco il perchè. Se non ci riesco sarebbe il caso di chiedere supporto sul forum ufficiale!
Titolo: Re:Form / Child e TButton
Inserito da: xinyiman - Aprile 12, 2012, 04:45:11 pm
Non sono riuscito a trovare il bandolo della matassa. Sembra collegato all'oggetto chiamante! Prova a chiedere sul forum ufficiale, e se poi risolvi facci sapere come hai fatto. E' curiosa questa cosa!
Titolo: Re:Form / Child e TButton
Inserito da: Maverich - Aprile 13, 2012, 02:23:01 pm
Ho provato a registrami sul Forum Inglese, ma niente non accetta:

1 - inserisco le lettere visualizzate (es: HCNATU)
2 - scrivo Lazarus al contrario (surazaL)
3 - inserisco 1+2 (es: HCNATUsurazaL)

ti risultano problemi ?
Titolo: Re:Form / Child e TButton
Inserito da: xinyiman - Aprile 13, 2012, 02:52:01 pm
Che io sappia nessun problema, ma rispetti maiuscole e minuscole?!
Titolo: Re:Form / Child e TButton
Inserito da: nomorelogic - Aprile 13, 2012, 03:28:20 pm
3 - inserisco 1+2 (es: HCNATUsurazaL)


1+2 = three
;)
Titolo: Re:Form / Child e TButton
Inserito da: Maverich - Aprile 13, 2012, 04:28:26 pm
E' vero, non ci avevo proprio pensato,
registrazione effettuata grazie.
Titolo: Re:Form / Child e TButton
Inserito da: Maverich - Aprile 13, 2012, 09:18:35 pm
Non sono riuscito a trovare il bandolo della matassa. Sembra collegato all'oggetto chiamante! Prova a chiedere sul forum ufficiale, e se poi risolvi facci sapere come hai fatto. E' curiosa questa cosa!

ho avuto questa risposta
http://www.lazarus.freepascal.org/index.php/topic,16618.0.html

"Also, not related to the error, but you have a memory leak relating to the fChild global variable. If you create 2 forms, they both originally tried to be included in that 1 same variable. But second form overrides this, leaving first form floating in memory on its own."

ma francamente non capisco come un'stanza "fChild" ad un form non in memoria possa creare il problema;

Inoltre, non legati all'errore, ma hai una perdita di memoria concernenti la variabile globale fChild. Se si creano 2 forme, entrambi originariamente cercano di essere inclusi in tale variabile (fChild). Ma la seconda Form esegue l'override di questo, lasciando la prima forma galleggiante in memoria.

- forse ho capito male l'inglese
- oppure si deve cambiare tecnica, pero' per creare un Form a runtime devo avere un'istanza a questo.

suggerimenti ?
Titolo: Re:Form / Child e TButton
Inserito da: nomorelogic - Aprile 14, 2012, 09:43:29 am
non ho scaricato il sorgente ma penso di aver capito a cosa si riferiscono con il 'memory leak'

in pratica se nel codice OnClick del bottone crei una istanza di una form con
Citazione
fChild := TForm.Create(self);

l'indirizzo della nuova istanza viene memorizzato in fChild, ora: se in fChild c'era già l'indirizzo di un'altra istanza precedentemente creata ti trovi nella condizione di avere 2 istanze in memoria ha mai 1 solo puntatore e quindi puoi gestire (e chiudere) solo una di queste 2 istanze, l'altra rimarrà in memoria.

per ovviare a questo, ci sono 2 modi:

sicuramente l'utilizzo congiunto di tutti e 2 gli accorgimenti da garanzie migliori, l'importante è capire se bisogna creare una nuova istanza o no.