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.

     
  • 相关阅读:
    Sublime Text shift+ctrl妙用(转载)
    编写一致的符合习惯的javascript
    Vue 部署单页应用,刷新页面 404/502 报错
    http 缓存策略浅析
    Vue 项目优化,持续更新...
    web安全之——XSS、CSRF
    javascript 易错知识点合集
    深入理解 js this 绑定机制
    javascript 模块依赖管理的本质
    VUE 项目刷新路由指向index.html
  • 原文地址:https://www.cnblogs.com/dusf/p/12231856.html
Copyright © 2011-2022 走看看