Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-07-2006, 17:20   #1
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
[JAVA]Tempo esecuzione codice

Come posso sapere quanto ci mette in termini di tempo ad eseguire due pezzi di codice diverso?
In particolare vorrei sapere se fa prima a fare:
Codice:
if(buffer.getRGB(x,y)==buffer.getRGB(0,0))
dove buffer è un bufferedImage di elevate dimensioni

o fa prima a fare:
Codice:
if(matr[x][y])
dove matr è una matrice di boolean.

Qual'è il più veloce nell'esecuzione?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 18:58   #2
pumppkin
Member
 
Iscritto dal: Feb 2005
Messaggi: 295
puoi provare ad utilizzare questo codice (sinceramente l'ho usato solo una volta ma su una procedura intera...non so se esistono dei comandi fatti apposta per questo):
Codice:
Calendar date1 = Calendar.getInstance();
if(buffer.getRGB(x,y)==buffer.getRGB(0,0))
Calendar date2 = Calendar.getInstance();
e poi dovresti farti stampare la differenza di tempo tra le due date
(float)(date2.getTime().getTime()-date1.getTime().getTime())/1000)

forse nel tuo caso anzichè 1000 dovresti usare 10000 o 100000...

puoi fare la stessa cosa con if(matr[x][y])
pumppkin è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 21:44   #3
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Mmmm mi da sempre 0.0...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 11-07-2006, 22:01   #4
ally
Bannato
 
L'Avatar di ally
 
Iscritto dal: Jan 2003
Città:
Messaggi: 4423
...ciao...

...potresti provare con...

float inizio = System.getCurrentMills();

...tuo codice...

float fine = System.getCurrentMills()-inizio;

...è codice scritto al volo...non sono certo della sintassi...

...ciao...
ally è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2006, 04:24   #5
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da MEMon
Mmmm mi da sempre 0.0...
Certo, la divisione (meglio, il cast) e' messo nella posizione sbagliata.
Ad ogni modo, ti consiglio di non dividere: otterrai il risultato in millisecondi, che e' una ragionevole misura per quello che vuoi fare.

Altro consiglio: il tempo di una singola operazione come quella in esame, e' difficile da prendere, visto che verra' eseguita in un tempo molto piccolo.
Fortunatamente, l'operazione che vuoi misurare puo' essere ripetuta (ovviamente non sempre sei in questa condizione).

Se metti in un ciclo

Calendar start_time = Calendar.getInstance();
for (int i = 0; i < 1000000; i++)
operazione_sotto_osservazione();
Calendar end_time = Calendar.getInstance();

ecco che i microsecondi diventano secondi, e le differenze temporali fra le due operazioni si moltiplicano.


High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2006, 12:34   #6
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ho fatto come mi hai detto!
Grazie funziona benissimo così, non pensavo ci fosse così tanta differenza e invece...incredibile...
Con questo codice mi stampa un valore di circa -3600 (perchè negativo poi?):
Codice:
import java.awt.image.*;
import java.awt.*;
import javax.swing.*;
import java.util.*;

public class Tempo {

	public static void main(String[] args) {
		PixMap buffer=new PixMap("./s0.png");
		boolean[][] matr=buffer.matricePixel();
		BufferedImage bf=buffer.bufferImm();
		System.out.println("START...");
		for(int j=0;j<10;j++){
			Calendar start_time = Calendar.getInstance();
			for (int i=0;i<10000000;i++){
				boolean b=bf.getRGB(20,20)==bf.getRGB(0,0);
			}
			Calendar end_time = Calendar.getInstance();
			System.out.println("Ciclo n"+j+"="+(start_time.getTime().getTime()-end_time.getTime().getTime()));
		}
	}
}
Mentre con questo solo -45!!! E' decisamente più veloce!
Codice:
import java.awt.image.*;
import java.awt.*;
import javax.swing.*;
import java.util.*;

public class Tempo {

	public static void main(String[] args) {
		PixMap buffer=new PixMap("./s0.png");
		boolean[][] matr=buffer.matricePixel();
		BufferedImage bf=buffer.bufferImm();
		System.out.println("START...");
		for(int j=0;j<10;j++){
			Calendar start_time = Calendar.getInstance();
			for (int i=0;i<10000000;i++){
				boolean b=matr[20][20];
			}
			Calendar end_time = Calendar.getInstance();
			System.out.println("Ciclo n"+j+"="+(start_time.getTime().getTime()-end_time.getTime().getTime()));
		}
	}
}
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2006, 13:14   #7
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da MEMon
Ho fatto come mi hai detto!
...
Con questo codice mi stampa un valore di circa -3600 (perchè negativo poi?):
...
Hai fatto start - end, per cui e' negativo. Poco male, tanto si capisce benissimo

High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 12-07-2006, 16:45   #8
AngeL)
Senior Member
 
L'Avatar di AngeL)
 
Iscritto dal: May 2006
Città: Salerno
Messaggi: 936
si puo fare una cosa del genere in C/C++ ?
AngeL) è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2006, 06:05   #9
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da AngeL)
si puo fare una cosa del genere in C/C++ ?
Certamente.
Se hai la possibilita' di eseguire delle ripetizioni del comando, come in questo caso, puoi usare la time() (ti restituisce il numero di secondi trascorsi dal 1/1/1970).
In alternativa, molte implementazioni su diversi sistemi operativi ti danno a disposizione dei metodi piu' precisi, che possono arrivare fino ai nanosecondi.

Usando la time:

time_t start = time(NULL);
<Operazioni di cui vuoi verificare il tempo>
time_t stop = time(NULL);

tempo_trascorso = stop - start;

High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 13-07-2006, 10:08   #10
AngeL)
Senior Member
 
L'Avatar di AngeL)
 
Iscritto dal: May 2006
Città: Salerno
Messaggi: 936
grazie.
ma se l'operazione da verificare venisse eseguita in meno di un secondo come posso fare per avere il risultato in millisecondi?
AngeL) è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Una connessione diretta con AWS European...
La Toyota Yaris avrà una versione...
Minori sessualizzati da Grok: l'UE mette...
NIO stabilisce il nuovo record di scambi...
Dell Private Cloud sempre più ape...
Ennesimo incidente per la guida autonoma...
Dopo le maniglie, è il turno dei ...
Addio incendi incontrollati? Svolt dice ...
WINDTRE si mette in proprio: vender&agra...
The Mandalorian & Grogu: il trailer ...
OpenClaw sotto attacco: i malware infost...
Resident Evil Requiem: pre-load dal 25 f...
Vaticano, la Messa si traduce in 60 ling...
Kia prepara il facelift della Kia EV5: n...
La nuova Alpine A110 elettrica sfrutterà...
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: 19:19.


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