zoukankan      html  css  js  c++  java
  • 每天固定时间运行Task 扫描任务

    When you want to make some delay in running code you can use Task.Delay(TimeSpan interval) method . This method is similar to Thread.Sleep, but it is nicer. The argument of the method represent TimeSpan type. For example if you want to wait 5 second you can call the following code:

    Task.Delay(TimeSpan.FromSeconds(5));

    Or you want to wait 2 hours:


    Task.Delay(TimeSpan.FromHourss(2));

    You can easily use Task.Delay to run some code at certain time. For example you want to run some method every day at 1:00:00 AM. To implement this example you can use Task.Delay method on the following way:
    First Convert the time in to DateTime type. Make diference between now and the time you want to run the code. Call Delay method with TimeSpan of previous time interval. The following code solve this problem:

    class Program
    {
    static void Main(string[] args)
    {
    //Time when method needs to be called
    var DailyTime = "01:00:00";
    var timeParts = DailyTime.Split(new char[1] { ':' });

    var dateNow = DateTime.Now;
    var date = new DateTime(dateNow.Year, dateNow.Month, dateNow.Day,
    int.Parse(timeParts[0]), int.Parse(timeParts[1]), int.Parse(timeParts[2]));
    TimeSpan ts;
    if (date > dateNow)
    ts = date - dateNow;
    else
    {
    date = date.AddDays(1);
    ts = date - dateNow;
    }

    //waits certan time and run the code
    Task.Delay(ts).ContinueWith((x)=> SomeMethod());

    Console.Read();
    }

    static void SomeMethod()
    {
    Console.WriteLine("Method is called.");
    }
    }

    If you want that code to run every day, just put it in while loop.

    Happy programming.

     
  • 相关阅读:
    cnetos7安装mysql并开启慢日志查询
    ansible-playbook安装zabbix_server,agent监控
    mysql性能优化之服务器参数配置-内存配置
    什么影响了mysql的性能-存储引擎层
    什么影响了mysql的性能-硬件资源及系统方面优化
    redis基本操作使用
    cmd下操作MySQL
    Win10安装MySQL
    Linux 操作
    PySpark—DataFrame笔记
  • 原文地址:https://www.cnblogs.com/dusf/p/12231856.html
Copyright © 2011-2022 走看看