Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/304.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 后台工作人员检查它的时间';现在是午夜吗?_C#_Winforms_Backgroundworker - Fatal编程技术网

C# 后台工作人员检查它的时间';现在是午夜吗?

C# 后台工作人员检查它的时间';现在是午夜吗?,c#,winforms,backgroundworker,C#,Winforms,Backgroundworker,我想为WinForm创建一个后台工作程序,每当午夜来临时触发代码 我知道怎么做,但我很确定这不是最好的方法 while(1==1) { //if Datetime.Now == midnight, execute code //sleep(1second) } 相反,您可以使用计时器并将计时器滴答声间隔设置为从现在()到午夜之间的时间。您可以使用它来安排时间。在这个场景中,这可能就像一门大炮,可以杀死一只蚊子,但这是我所知道的唯一一个调度作业框架,而且工作非常出色 使用System.Timer

我想为WinForm创建一个后台工作程序,每当午夜来临时触发代码

我知道怎么做,但我很确定这不是最好的方法

while(1==1)
{
//if Datetime.Now == midnight, execute code
//sleep(1second)
}

相反,您可以使用计时器并将计时器滴答声间隔设置为从现在()到午夜之间的时间。

您可以使用它来安排时间。在这个场景中,这可能就像一门大炮,可以杀死一只蚊子,但这是我所知道的唯一一个调度作业框架,而且工作非常出色

使用
System.Timers.Timer
在应用程序启动时,只需计算
DateTime.Now
DateTime.Today.AddDays(0)
之间的差异。然后设置该金额的间隔

我最近确实做了这样的事情:

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;
}

用法:
DayChangedNotified.DayChanged+=..
不要使用轮询。相反,设置一个计时器任务,将其设置为午夜启动,并向进程添加一个事件

 TimeSpan timeBetween = DateTime.Today.AddDays(1) - DateTime.Now;

 System.Timers.Timer t = new System.Timers.Timer();
 t.Elapsed += new System.Timers.ElapsedEventHandler(t_Elapsed);
 t.Interval = 1000 * timeBetween.Seconds;
 t.Start();

我不知道为什么在微软几年前通过添加一个windows服务来处理计时问题来解决这类问题时,投票解决方案被选中。只需创建一个计划任务来运行exe。没有额外的开销。

我有点不明白为什么需要WinForm,它会在午夜运行吗?如果您只需要运行一些排序进程,请使用windows计划程序在午夜运行它。(在XP上,但我相信Win server应该类似)控制面板->计划任务->添加计划任务->填写向导。节省大量编码。

快速注释。。。如果您想要创建这样一个“无止境”循环(当然,它可能会有一个
中断
),您可以执行
而(true){}
1==1
的计算结果为
true
。这是公认的标准吗?我从来都不确定使用1是否合适==1@Soo:没有。计时器不会阻塞(停止其余代码--)。一旦间隔结束,它将调用
Tick
事件。此时,如果愿意,您可以停止计时器,计算下一个间隔并重新启动它。不,System.Timers会在另一个线程上触发,因此您需要注意的是在计时器的事件处理程序中调用Invoke。或者改为使用System.Windows.Forms.timer,此线程会触发勾号()窗体线程中的事件。因此,在触发t_经过之后,是否重新计算了timeBetween?您将在t_经过的方法中重新计算间隔。
 TimeSpan timeBetween = DateTime.Today.AddDays(1) - DateTime.Now;

 System.Timers.Timer t = new System.Timers.Timer();
 t.Elapsed += new System.Timers.ElapsedEventHandler(t_Elapsed);
 t.Interval = 1000 * timeBetween.Seconds;
 t.Start();