I’m writing trading software and need to QoS one method that should not be executed more often than 10 times per second. As I’m begginer in C# and almost not familar with libraries I would like to double-check if my code is “optimal”. I’m using Stopwatch because I don’t know any other timers in C#.
Stopwatch updateStopwatch = Stopwatch.StartNew();
private void update()
{
if (updateStopwatch.ElapsedMilliseconds < 100)
{
Console.WriteLine("!skip update " + updateStopwatch.ElapsedMilliseconds);
return;
} else
{
Console.WriteLine("!update");
updateStopwatch.Restart();;
}
// do work here
}
upd Now it seems that Stopwatch is pretty good for this task. However probably it would be too slow, if so probably DateTime would be better. sell also Stopwatch vs. using System.DateTime.Now for timing events
Your technique of using
Stopwatchis the best solution to prevent the code from executing more frequently. As others have said, using aTimeris a better solution if you want to make sure that the method is executed on a schedule.Any approach based on
DateTimeis fundamentally broken because it will fail when the date changes. This is especially noticeable during the Daylight Saving Time switches. When we “spring ahead”, there’s the potential of the update running twice in quick succession because the code thinks that it’s been an hour since the previous update. That’s not too bad. But when we “fall back”, the update will be suspended for a full hour because the last update time is set an hour ahead.The same kind of thing can happen, although not as severely, if your computer is set to update its time periodically from an NTP server. If the time is set ahead, then there is the potential for two updates to happen in quick succession. If the time is set back, there’s the potential for updates not to happen for the amount of time the clock was set back.
There are ways around the problem (such as using the absolute value of the number of milliseconds), but then you’re just putting a bandage on a broken solution. You shouldn’t depend on
DateTimefor intervals like this because your program isn’t in control of the system clock–it can change at any time.Stopwatchis the only reasonable solution here because it depends on the CPU’s performance counter, which only increases. You don’t have the problems of somebody setting the counter back, and you don’t have the rollover problems you would encounter with something likeEnvironment.TickCount.There’s some idea that
Stopwatchincurs a performance penalty thatDateTimedoesn’t. My testing shows that to be untrue.