Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
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.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-04-2003, 18:21   #1
miondere
Member
 
L'Avatar di miondere
 
Iscritto dal: Sep 2001
Città: Firenze
Messaggi: 216
Tempo esecuzione [C++]

Volevo chiedervi questo:
esiste nella libreria standard una funzione che mi restituisca in
millisecondi (o anche di ordine inferiore) la durata di esecuzione di una
parte del prg, cioè una sorta di contatore che parte in un certo punto (che
posso anche fermare) e in determinati "checkpoint" da me decisi possa
salvare il suo valore dentro una variabile...
Esiste? Spero proprio di sì...
Grazie...
miondere è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2003, 18:57   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Nella libreria standard non credo...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2003, 19:09   #3
miondere
Member
 
L'Avatar di miondere
 
Iscritto dal: Sep 2001
Città: Firenze
Messaggi: 216
Quote:
Originally posted by "cionci"

Nella libreria standard non credo...
Infatti ho provato a cercare su MSDN ma non ho trovato niente a riguardo...
Sai dove posso trovare una funzione di questo tipo?


Cmq il mio professore aveva detto che esisteva ed era: % man getrusage
Ho provato a guardare nella libreria standard, ma nn c'era niente del genere...ti dice qualcosa "getrusage"?
miondere è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2003, 19:33   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ma non è della libreria std...
Se da quello che ho capito vuoi il tempo in cui il tuo processo ha occupato il processore allora per Windows puoi usare GetProcessTimes...per Linux quella che ti ha detto il tuo professore...

Se invece ti interessa una misura del assoluta del tempo (non so di quello usato dal processo) allora puoi usare timeGetTime...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2003, 22:11   #5
miondere
Member
 
L'Avatar di miondere
 
Iscritto dal: Sep 2001
Città: Firenze
Messaggi: 216
Perchè mi da errore?

La compilazione del seguente codice (compilo con Visual Studio) va a buon fine, ma quando faccio il link mi da il seguente errore:

--------------------Configuration: gettime - Win32 Debug--------------------
Linking...
gettime.obj : error LNK2001: unresolved external symbol __imp__timeGetTime@0
Debug/gettime.exe : fatal error LNK1120: 1 unresolved externals
Error executing link.exe.

gettime.exe - 2 error(s), 0 warning(s)



#include <windows.h>

#include <mmsystem.h>


int main()
{

DWORD snapshot1;

snapshot1=timeGetTime();

return 0;
}
miondere è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 00:33   #6
miondere
Member
 
L'Avatar di miondere
 
Iscritto dal: Sep 2001
Città: Firenze
Messaggi: 216
Ho risolto il problema: si deve fare il link anche con la winmm.lib
miondere è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 01:23   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Comunque timeGetTime è utile per fare le differenze di tempo...
Così com'è non ti serve a molto, infatti ritorno il tempo trascorsa da quando Windows è stato avviato...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 08:18   #8
lombardp
Senior Member
 
L'Avatar di lombardp
 
Iscritto dal: Jun 2002
Città: Firenze
Messaggi: 630
Per fare un profiling "artigianale" io utilizzo la funzione QueryPerformanceCounter (e le altre correlate dell'SDK) che restituisce il valore corrente di un contatore hardware all'interno dei microprocessori. La frequenza di conteggio si ottiene con QueryPerformanceFrequency e usando due volte di seguito QueryPerformanceCounter si ottiene una stima dell'overhead dovuto alla chiamata della funzione.

Dimenticavo, la risoluzione dovrebbe essere sotto il microsecondo (l'inverso della frequenza del contatore hw).
__________________
---> Lombardp
CSS Certified Expert (Master Level) at Experts-Exchange
Proud user of LITHIUM forum : CPU technology
Webmaster of SEVEN-SEGMENTS : Elettronica per modellismo
lombardp è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 11:03   #9
verloc
Senior Member
 
L'Avatar di verloc
 
Iscritto dal: Jan 2000
Messaggi: 551
#include <windows.h>
#include "Duration.h"

...

CDuration timer;
timer.Start();

--codice da misurare-

timer.Stop();
cout <<endl<< "Durata della funzione " << timer.GetDuration()/1000.0 << " milliseconds" << endl;
............

Codice:
//file Duration.h
#pragma once

class CDuration
{
protected:
	LARGE_INTEGER m_liStart;
	LARGE_INTEGER m_liStop;

	LONGLONG m_llFrequency;
	LONGLONG m_llCorrection;

public:
	CDuration(void);

	void Start(void);
	void Stop(void);
	double GetDuration(void) const;
};

inline CDuration::CDuration(void)
{
	LARGE_INTEGER liFrequency;

	QueryPerformanceFrequency(&liFrequency);
	m_llFrequency = liFrequency.QuadPart;

	// Calibration
	Start();
	Stop();

	m_llCorrection = m_liStop.QuadPart-m_liStart.QuadPart;
}

inline void CDuration::Start(void)
{
	// Ensure we will not be interrupted by any other thread for a while
	Sleep(0);
	QueryPerformanceCounter(&m_liStart);
}

inline void CDuration::Stop(void)
{
	QueryPerformanceCounter(&m_liStop);
}

inline double CDuration::GetDuration(void) const
{
	return (double)(m_liStop.QuadPart-m_liStart.QuadPart-m_llCorrection)*1000000.0 / m_llFrequency;
}
verloc è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 12:27   #10
miondere
Member
 
L'Avatar di miondere
 
Iscritto dal: Sep 2001
Città: Firenze
Messaggi: 216
Quote:
Originally posted by "cionci"

Comunque timeGetTime è utile per fare le differenze di tempo...
Così com'è non ti serve a molto, infatti ritorno il tempo trascorsa da quando Windows è stato avviato...
Infatti mi serve per vedere da un punto del processo fino ad un altro quanto tempo è trascorso...prendo l'istante iniziale e poi faccio la differenza
miondere è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 15:23   #11
verloc
Senior Member
 
L'Avatar di verloc
 
Iscritto dal: Jan 2000
Messaggi: 551
Ho dimenticato di dire che la classe non l'ho fatta io.
Adoperavo le Api in maniera "rozza" e quando mi decisi a farne una classe
beccai questa per caso,mi risparmiò il lavoro.
Oltretutto alla taratura non ci avevo pensato
verloc è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2003, 15:29   #12
verloc
Senior Member
 
L'Avatar di verloc
 
Iscritto dal: Jan 2000
Messaggi: 551
Quote:
Originally posted by "miondere"



Infatti mi serve per vedere da un punto del processo fino ad un altro quanto tempo è trascorso...prendo l'istante iniziale e poi faccio la differenza
Guarda che se tenti di misurare quanto tempo ci vuole ad eseguire
qualche funzione 9 su 10 ti darà 0 perchè sotto il millisecondo non va.
Normalmente si sta sotto,molto sotto.
verloc è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
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...
Oracle NetSuite si potenzia con nuove fu...
Musica generata con l'IA: Sony lavora a ...
Cyberpunk 2077 in versione PC su smartph...
BYD si gioca un grosso jolly: pronta Rac...
Samsung annuncia l'arrivo in Italia dei ...
Offerta lancio Pixel 10a: come ottenere ...
Google presenta Pixel 10a: poche le novi...
Caos F1 2026: 14 monoposto senza omologa...
Tesla festeggia il primo Cybercab prodot...
Desktop piccolo e potente? NZXT H2 Flow ...
Polestar spinge sull'acceleratore: arriv...
Nuovo record mondiale nel fotovoltaico: ...
L'ultimo baluardo cade: fine supporto pe...
'Il mondo non ha mai visto nulla di simi...
La Commissione europea mette sotto indag...
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: 20:44.


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