Verwenden Sie eine System.Timers.Timer
und bei der Anwendung Start nur berechnen Sie den Unterschied zwischen DateTime.Now
und DateTime.Today.AddDays(0)
. Stellen Sie dann das Intervall für diesen Betrag ein.
Ich habe tatsächlich so etwas wie dies vor kurzem:
public static class DayChangedNotifier
{
private static Timer timer;
static DayChangedNotifier()
{
timer = new Timer(GetSleepTime());
timer.Elapsed += (o, e) =>
{
OnDayChanged(DateTime.Now.DayOfWeek);
timer.Interval = this.GetSleepTime();
};
timer.Start();
SystemEvents.TimeChanged += new EventHandler(SystemEvents_TimeChanged);
}
private static void SystemEvents_TimeChanged(object sender, EventArgs e)
{
timer.Interval = GetSleepTime();
}
private static double GetSleepTime()
{
var midnightTonight = DateTime.Today.AddDays(1);
var differenceInMilliseconds = (midnightTonight - DateTime.Now).TotalMilliseconds;
return differenceInMilliseconds;
}
private static void OnDayChanged(DayOfWeek day)
{
var handler = DayChanged;
if (handler != null)
{
handler(null, new DayChangedEventArgs(day));
}
}
public static event EventHandler<DayChangedEventArgs> DayChanged;
}
UND:
public class DayChangedEventArgs : EventArgs
{
public DayChangedEventArgs(DayOfWeek day)
{
this.DayOfWeek = day;
}
public DayOfWeek DayOfWeek { get; private set; }
}
Verbrauch: DayChangedNotified.DayChanged += ....
Quick Hinweis ... Wenn Sie jemals eine „endlose“ Schleife so erstellt werden soll (die eine 'break', natürlich haben könnte), können Sie' while (true) {} '. '1 == 1 'wird trotzdem als' wahr 'ausgewertet. –
Ist das der akzeptierte Standard? Ich war mir nie sicher, ob ich 1 == 1 – sooprise