bsummer
23-08-2004, 10:34
Ciao a tutti.
Premetto che sarò lungo :D
Tempo fa aprii una discussione chiedendo come si potesse rilevare se più istanze di una generica applicazione stessero girando (sotto win). Se la domanda fosse stata "come faccio a capire se il MIO programma ha più istanze attive" allora le risposte sarebbero state facili (di esempi ne è lastricata internet) ma di quella mia domanda nessuno sembra sapere la risposta :cry:
Con un po' di fantasia ho cercato di risolvere il problema. Usando l'API FindWindow ho fatto una ricerca sull'applicazione X, poi usando l'API SetWindowText ne ho modificato la caption in Y e quindi usando nuovamente FindWindow ho fatto di nuovo una ricerca su X. A questo punto è ovvio che se la Find mi restituisce un handle (non null) di X sono aperte più istanze.
Ovviamente il metodo è alquanto blando, esistono mille e più casi per i quali tale ricerca può essere ingannata o fornire risultati "non certi", tuttavia per il mio caso specifico questa soluzione mi pareva ottima.
Solo che, ovviamente, le cose non sono andate per il meglio.
Infatti mi capita che il mio programmino, usando il sopracitato metodo, mi dia dei "false positive", ovvero mi rilevi più istanze quando in realtà ve n'è una sola...
Ho pensato che fosse un problema di sincronizzazione col thread che puntualmente, con una certa frequenza, fa il controllo: cerco finestra, modifico caption, lancio il thread di controllo, per qualche strano motivo la modifica della caption viene fatta in ritardo e il thread il thread di controllo rileva la vecchia caption. Ho sincronizzato tutto in modo che questo non possa succedere, eppure puntualmente l'applicazione continua a rilevarmi che più istanze sono attive.
A questo punto m'è venuto un altro dubbio: vuoi vedere che si, la setTextWindow cambia la caption ma da qualche parte rimane il nome originale e la FindWindow controlla anche quello? Allora ho fatto una prova: la FindWindow restituisce l'handle della finestra oppure null se non trova il match. Ho salvato l'handle della finestra della quale modifico la caption, per vedere se questo era uguale a l'handle della finestra che mi trova ancora col vecchio nome. Con mia somma sorpresa ho scoperto che l'handle è diverso!
Ricapitolando: cerco una finestra con un certo titolo X, mi ricavo l'handle, uso l'handle con la SetTextWindow per modificare il titolo in Y, cerco ancora X, lo trovo ma l'handle è diverso da prima. Ovviamente sono arcisicuro che l'applicazione in questione è attiva con una sola istanza. Il mistero s'infittisce quando salta fuori che non sempre la FindWindow mi ritrova l'applicazione col nome originale: il controllo è all'interno di un thread che si attiva 1 volta al secondo e generalmente mi sono accorto che il rilevamento "sbagliato" lo fa 1 sola volta per poi non ripetersi più.
E dopo tutta questa luuuunga storia veniamo al sodo: ma l'handle di una finestra, non dovrebbe essere sempre lo stesso per tutta la durata di esecuzione di un'applicazione? Da dove salta fuori quell'altro handle, diverso, che punta ad una finestra che non dovrebbe esistere? :confused:
Scusate la lunghezza del post, ma ho voluto essere preciso su alcuni dettagli in modo da farvi scartare a priori alcune possibilità, già da me vagliate.
Ciao
Premetto che sarò lungo :D
Tempo fa aprii una discussione chiedendo come si potesse rilevare se più istanze di una generica applicazione stessero girando (sotto win). Se la domanda fosse stata "come faccio a capire se il MIO programma ha più istanze attive" allora le risposte sarebbero state facili (di esempi ne è lastricata internet) ma di quella mia domanda nessuno sembra sapere la risposta :cry:
Con un po' di fantasia ho cercato di risolvere il problema. Usando l'API FindWindow ho fatto una ricerca sull'applicazione X, poi usando l'API SetWindowText ne ho modificato la caption in Y e quindi usando nuovamente FindWindow ho fatto di nuovo una ricerca su X. A questo punto è ovvio che se la Find mi restituisce un handle (non null) di X sono aperte più istanze.
Ovviamente il metodo è alquanto blando, esistono mille e più casi per i quali tale ricerca può essere ingannata o fornire risultati "non certi", tuttavia per il mio caso specifico questa soluzione mi pareva ottima.
Solo che, ovviamente, le cose non sono andate per il meglio.
Infatti mi capita che il mio programmino, usando il sopracitato metodo, mi dia dei "false positive", ovvero mi rilevi più istanze quando in realtà ve n'è una sola...
Ho pensato che fosse un problema di sincronizzazione col thread che puntualmente, con una certa frequenza, fa il controllo: cerco finestra, modifico caption, lancio il thread di controllo, per qualche strano motivo la modifica della caption viene fatta in ritardo e il thread il thread di controllo rileva la vecchia caption. Ho sincronizzato tutto in modo che questo non possa succedere, eppure puntualmente l'applicazione continua a rilevarmi che più istanze sono attive.
A questo punto m'è venuto un altro dubbio: vuoi vedere che si, la setTextWindow cambia la caption ma da qualche parte rimane il nome originale e la FindWindow controlla anche quello? Allora ho fatto una prova: la FindWindow restituisce l'handle della finestra oppure null se non trova il match. Ho salvato l'handle della finestra della quale modifico la caption, per vedere se questo era uguale a l'handle della finestra che mi trova ancora col vecchio nome. Con mia somma sorpresa ho scoperto che l'handle è diverso!
Ricapitolando: cerco una finestra con un certo titolo X, mi ricavo l'handle, uso l'handle con la SetTextWindow per modificare il titolo in Y, cerco ancora X, lo trovo ma l'handle è diverso da prima. Ovviamente sono arcisicuro che l'applicazione in questione è attiva con una sola istanza. Il mistero s'infittisce quando salta fuori che non sempre la FindWindow mi ritrova l'applicazione col nome originale: il controllo è all'interno di un thread che si attiva 1 volta al secondo e generalmente mi sono accorto che il rilevamento "sbagliato" lo fa 1 sola volta per poi non ripetersi più.
E dopo tutta questa luuuunga storia veniamo al sodo: ma l'handle di una finestra, non dovrebbe essere sempre lo stesso per tutta la durata di esecuzione di un'applicazione? Da dove salta fuori quell'altro handle, diverso, che punta ad una finestra che non dovrebbe esistere? :confused:
Scusate la lunghezza del post, ma ho voluto essere preciso su alcuni dettagli in modo da farvi scartare a priori alcune possibilità, già da me vagliate.
Ciao