High Performance Timer i Delphi

For rutine-stasjonære databaseapplikasjoner gjør sjelden en forskjell for sluttbrukere å legge til et eneste sekund til en oppgavs utførelsestid når du trenger å behandle millioner av treblad eller generere milliarder av unike tilfeldige tall, blir hastigheten på utførelsen viktigere.

Timer ut koden

I noen applikasjoner er veldig nøyaktige, målingsmetoder med høy presisjon tid viktige og heldigvis Delphi gir en teller med høy ytelse for å kvalifisere disse tider.

Bruker RTL Funksjon

Ett alternativ bruker funksjon. , definert i sysutils enhet, returnerer gjeldende systemdato og klokkeslett.

Noen få kodelinjer måler tiden mellom "start" og "stopp" for en eller annen prosess:

Nå-funksjonen returnerer gjeldende systemdato og -tid som er nøyaktig opptil 10 millisekunder (Windows NT og senere) eller 55 millisekunder (Windows 98).

I veldig små intervaller er presisjonen til "Nå" noen ganger ikke nok.

Bruker Windows API GetTickCount

For enda mer presise data, bruk GetTickCountWindows API funksjon.

instagram viewer
GetTickCount henter antall millisekunder som har gått siden systemet ble startet, men funksjonen har bare presisjonen på 1 ms og er kanskje ikke alltid nøyaktig hvis datamaskinen forblir påslått i lengre perioder tid.

Den forløpte tiden lagres som en DWORD-verdi (32-biters). Derfor vil tiden vikle rundt til null hvis Windows kjøres kontinuerlig i 49,7 dager.

GetTickCount er også begrenset til nøyaktigheten til systemtimeren (10/55 ms).

Høy presisjon Timer ut koden

Hvis PCen din støtter en høyoppløselig ytelsesdisk, bruker du QueryPerformanceFrequency Windows API-funksjon for å uttrykke frekvensen, i teller per sekund. Verdien på tellingen er prosessoravhengig.

De QueryPerformanceCounter -funksjonen henter gjeldende verdi på høyoppløselig ytelses teller. Ved å kalle denne funksjonen på begynnelsen og slutten av et kodeseksjon, bruker en applikasjon telleren som en høyoppløselig timer.

Nøyaktigheten til høyoppløselige tidtakere er rundt noen hundre nanosekunder. Et nanosekund er en tidsenhet som representerer 0.000000001 sekunder - eller 1 milliarddel av et sekund.

TStopWatch: Delphi Implementering av en høyoppløselig teller

Med et nikk til .Nett å navngi konvensjoner, en teller som TStopWatch tilbyr en høyoppløselig Delphi-løsning for nøyaktige tidsmålinger.

TStopWatch måler forløpt tid ved å telle timerfått i den underliggende timer-mekanismen.

  • De IsHighResolution Egenskapen indikerer om tidtakeren er basert på en høyoppløselig ytelsesteller.
  • De Start metoden begynner å måle forløpt tid.
  • De Stoppe metoden slutter å måle forløpt tid.
  • De ElapsedMilliseconds eiendom får den totale tiden som er gått i millisekunder.
  • De forløpt Egenskapen får den totale forløpne tiden i tidtakeren.

Her er et eksempel på bruk: