Utilizzare uno System.Timers.Timer
e all'avvio dell'applicazione, è sufficiente calcolare la differenza tra DateTime.Now
e DateTime.Today.AddDays(0)
. Quindi imposta l'intervallo per quella quantità.
ho effettivamente fatto qualcosa di proprio come questo di recente:
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;
}
E:
public class DayChangedEventArgs : EventArgs
{
public DayChangedEventArgs(DayOfWeek day)
{
this.DayOfWeek = day;
}
public DayOfWeek DayOfWeek { get; private set; }
}
Uso: DayChangedNotified.DayChanged += ....
Nota rapida ... Se si desidera creare un ciclo "infinito" come quello (che potrebbe avere un 'break ', ovviamente), si può fare' while (true) {} '. '1 == 1' valuta comunque' true'. –
È quello standard accettato? Non ero mai sicuro dell'opportunità di usare 1 == 1 – sooprise