Solved

1ms timer calling functions

Posted on 2016-08-09
3
92 Views
Last Modified: 2016-08-13
Hi,
For testing purposes I have this timer that calls a function every 1ms and adds +1 to a counter. This code works perfectly fine as its calling windows native code but is there anything in the .NET framework even close to 1ms or shall I stick to using native calls?

Public Class Form1
    Dim mHandler As TimerEventHandler
    Dim iCount As Long = 0
    Dim mTimerId As Integer

    <DllImport("winmm.dll")>
    Private Shared Function timeSetEvent(delay As Integer, resolution As Integer, handler As TimerEventHandler, user As IntPtr, eventType As Integer) As Integer
    End Function

    <DllImport("winmm.dll")>
    Private Shared Function timeBeginPeriod(millisecond As Integer) As Integer
    End Function

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        timeBeginPeriod(1)
        mHandler = New TimerEventHandler(AddressOf TimerCallback)
        mTimerId = timeSetEvent(1, 0, mHandler, IntPtr.Zero, 1)
    End Sub

    Private Delegate Sub TimerEventHandler(id As Integer, msg As Integer, user As IntPtr, dw1 As Integer, dw2 As Integer)
    Private Sub TimerCallback(id As Integer, msg As Integer, user As IntPtr, dw1 As Integer, dw2 As Integer)
        iCount += 1
    End Sub
End Class

Open in new window

0
Comment
Question by:XK8ER
  • 2
3 Comments
 
LVL 29

Expert Comment

by:anarki_jimbel
ID: 41749734
It's not quite clear what you want or what's required.

You may use stopwatch class to measure time elapsed: https://msdn.microsoft.com/en-us/library/system.diagnostics.stopwatch(v=vs.110).aspx
You may measure in milliseconds or in ticks. 1 tick - 100 ns.

Also you may use DateTime.Ticks property to measure times:
https://msdn.microsoft.com/en-us/library/system.datetime.ticks(v=vs.110).aspx
0
 
LVL 1

Author Comment

by:XK8ER
ID: 41749749
using DateTime is not a good suggestion as it has a resolution of about 15ms and also stopwatch is not good unless you use high resolution stopwatch.

the questions here is more of a concern than anything else, so i'm just worried if there are any casualties by using this code in a production environment or if it is a safe call.
0
 
LVL 29

Accepted Solution

by:
anarki_jimbel earned 500 total points
ID: 41749800
DateTime - correct  : )

I can't really see any problems with using Windows API.

On another hand, my understanding is that if a system supports high performance counters the .net stopwatch should be high resolution stopwatch. Have a look: https://msdn.microsoft.com/en-us/library/windows/desktop/dn553408(v=vs.85).aspx
0

Featured Post

Master Your Team's Linux and Cloud Stack!

The average business loses $13.5M per year to ineffective training (per 1,000 employees). Keep ahead of the competition and combine in-person quality with online cost and flexibility by training with Linux Academy.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Many of us here at EE write code. Many of us write exceptional code; just as many of us write exception-prone code. As we all should know, exceptions are a mechanism for handling errors which are typically out of our control. From database errors, t…
A long time ago (May 2011), I have written an article showing you how to create a DLL using Visual Studio 2005 to be hosted in SQL Server 2005. That was valid at that time and it is still valid if you are still using these versions. You can still re…
Along with being a a promotional video for my three-day Annielytics Dashboard Seminor, this Micro Tutorial is an intro to Google Analytics API data.
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question