Manugal
26-06-2010, 13:50
Ciao a tutti!
Ho sviluppato un programmino che esegue un determinato algoritmo e poi mi stampa a schermo i risultati. Questo algoritmo prende in input un array molto grande (di lunghezza 262000) e mi restituisce un array calcolato secondo l'algoritmo (non lo scrivo perché è un po' lungo). Siccome uso due thread che processano uno la prima metà dell'array e uno la seconda metà, ho bisogno di capire il tempo impiegato da ciascun thread. Ho utilizzato la clock_gettime() con l'argomento CLOCK_MONOTONIC e poi quando terminano i due thread sommo i tempi di esecuzione di entrambi per avere il tempo totale. Il problema è che alla prima esecuzione (cioè appena dopo aver compilato) il timer mi restituisce 6 sec, mentre dalla seconda esecuzione in poi sempre 8 secondi. :confused:
E' una cosa normale? Anche perché ho sviluppato anche la versione monothread e quella impiega sempre 6,97 secondi ad ogni esecuzione (lì però ho usato clock() per cronometrare l'algoritmo).
P.S. : Entrambe le versioni le ho compilate con il flag di ottimizzazione O3.
Ho sviluppato un programmino che esegue un determinato algoritmo e poi mi stampa a schermo i risultati. Questo algoritmo prende in input un array molto grande (di lunghezza 262000) e mi restituisce un array calcolato secondo l'algoritmo (non lo scrivo perché è un po' lungo). Siccome uso due thread che processano uno la prima metà dell'array e uno la seconda metà, ho bisogno di capire il tempo impiegato da ciascun thread. Ho utilizzato la clock_gettime() con l'argomento CLOCK_MONOTONIC e poi quando terminano i due thread sommo i tempi di esecuzione di entrambi per avere il tempo totale. Il problema è che alla prima esecuzione (cioè appena dopo aver compilato) il timer mi restituisce 6 sec, mentre dalla seconda esecuzione in poi sempre 8 secondi. :confused:
E' una cosa normale? Anche perché ho sviluppato anche la versione monothread e quella impiega sempre 6,97 secondi ad ogni esecuzione (lì però ho usato clock() per cronometrare l'algoritmo).
P.S. : Entrambe le versioni le ho compilate con il flag di ottimizzazione O3.