最近进行了一次需求和Windows Schedule task相关职能,通过schedule,计算下一次运行task时间。

它用于由第三方DLL实现,以下网站,以下载来自:

http://taskscheduler.codeplex.com/

1. 在Schedule Task里添加一个task。命名为“testJing”, trigger设置为每五天

添加一个Trigger,例如以下图:

2. 使用VS2012,创建一个Console Application,命名为ScheduleTaskDemo

3.加入引用。

从上述的站点下载(http://taskscheduler.codeplex.com/releases/view/120747),解压后,找到Microsoft.Win32.TaskScheduler.dll(我用的是v4.0目录下的,我建的application的.NET framework 4.5)

4. 打开program.cs文件。代码例如以下:

方法一:

using Microsoft.Win32.TaskScheduler;

      using System;

public static void Main(string[] args)

        {

            using (TaskService ts = new TaskService())

            {

                Task task = ts.FindTask("testJing");

                DateTime nextRunTime = task.NextRunTime;

                Console.WriteLine("NextRunTime:" + nextRunTime);

            }

        }

NextRunTime 就可以获取下次跑task的时间。

这是直接用Task的属性NextRunTime,以下是我自己写的方法获取next run time.

方法二:使用Task里的一系列属性来计算,代码例如以下:

        public static void Main(string[] args)
{
try
{
DateTime? beginDateGMT = null;
DateTime? endDateGMT = null;
GetDaysInterval(out beginDateGMT, out endDateGMT);
if (!beginDateGMT.HasValue || !endDateGMT.HasValue)
{
throw new Exception("BeginDateGMT(" + beginDateGMT + ") or EndDateGMT(" + endDateGMT + ") is null. Please check schedule setting.");
}
else
{
Console.WriteLine("BeginDateGMT:" + beginDateGMT + ", EndDateGMT:" + endDateGMT);
}
}
catch (Exception ex)
{
throw;
} Console.Read();
}

        private static void GetDaysInterval(out DateTime? beginDateGMT, out DateTime? endDateGMT)
{
using (TaskService ts = new TaskService())
{
Task task = ts.FindTask("testJing");
TaskTriggerType taskTriggerType = task.Definition.Triggers[0].TriggerType;
//// get current day, e.g. 2014/11/10 00:00:00
DateTime nowGMT = DateTime.Now;
nowGMT = new DateTime(nowGMT.Year, nowGMT.Month, nowGMT.Day, 0, 0, 0);
beginDateGMT = nowGMT;
endDateGMT = null;
switch (taskTriggerType)
{
case TaskTriggerType.Daily:
DailyTrigger dailyTrigger = task.Definition.Triggers[0] as DailyTrigger;
if (dailyTrigger.DaysInterval > 0)
{
endDateGMT = beginDateGMT.Value.AddDays(dailyTrigger.DaysInterval);
}
else
{
throw new Exception("ScheduleType is daily, but daysInterval <= 0.");
}
break;
case TaskTriggerType.Weekly:
WeeklyTrigger weeklyTrigger = task.Definition.Triggers[0] as WeeklyTrigger;
if (weeklyTrigger.WeeksInterval > 0)
{
endDateGMT = beginDateGMT.Value.AddDays(weeklyTrigger.WeeksInterval * 7);
}
else
{
throw new Exception("ScheduleType is weekly, but weeksInterval <= 0.");
} break;
case TaskTriggerType.MonthlyDOW:
case TaskTriggerType.Monthly:
switch (taskTriggerType)
{
case TaskTriggerType.Monthly:
MonthlyTrigger monthlyTrigger = task.Definition.Triggers[0] as MonthlyTrigger;
endDateGMT = beginDateGMT.Value.AddMonths(1);
break;
case TaskTriggerType.MonthlyDOW:
MonthlyDOWTrigger monthlyDOWTrigger = task.Definition.Triggers[0] as MonthlyDOWTrigger;
if ((monthlyDOWTrigger.WeeksOfMonth == WhichWeek.FirstWeek
|| monthlyDOWTrigger.WeeksOfMonth == WhichWeek.SecondWeek || monthlyDOWTrigger.WeeksOfMonth == WhichWeek.ThirdWeek
|| monthlyDOWTrigger.WeeksOfMonth == WhichWeek.FourthWeek || monthlyDOWTrigger.WeeksOfMonth == WhichWeek.LastWeek)
&& (monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Sunday
|| monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Monday || monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Tuesday
|| monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Wednesday || monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Thursday
|| monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Friday || monthlyDOWTrigger.DaysOfWeek == DaysOfTheWeek.Saturday))
{
DateTime nextMonthFirstDay = new DateTime(beginDateGMT.Value.AddMonths(1).Year, beginDateGMT.Value.AddMonths(1).Month, 1, 0, 0, 0);
DateTime nextMonthLastDay = nextMonthFirstDay.AddMonths(1).AddDays(-1);
if (monthlyDOWTrigger.WeeksOfMonth == WhichWeek.LastWeek)
{
DayOfWeek? dayOfWeek = GetDayOfWeek(monthlyDOWTrigger.DaysOfWeek);
while (nextMonthLastDay >= nextMonthFirstDay)
{
if (nextMonthLastDay.DayOfWeek == dayOfWeek.Value)
{
endDateGMT = nextMonthLastDay;
break;
}
nextMonthLastDay = nextMonthLastDay.AddDays(-1);
}
}
else
{
//// weeksOfMonth: 1,2,3,4; daysOfWeekForMonth:7,1,2,3,4,5,6;
int weeksOfMonthInt = 0;
switch (monthlyDOWTrigger.WeeksOfMonth)
{
case WhichWeek.FirstWeek:
weeksOfMonthInt = 1;
break;
case WhichWeek.SecondWeek:
weeksOfMonthInt = 2;
break;
case WhichWeek.ThirdWeek:
weeksOfMonthInt = 3;
break;
case WhichWeek.FourthWeek:
weeksOfMonthInt = 4;
break;
default:
weeksOfMonthInt = 0;
break;
} if (weeksOfMonthInt > 0 && weeksOfMonthInt <= 4)
{
DayOfWeek? dayOfWeek = GetDayOfWeek(monthlyDOWTrigger.DaysOfWeek);
int countDayOfWeek = 0;
while (nextMonthLastDay >= nextMonthFirstDay)
{
if (nextMonthFirstDay.DayOfWeek == dayOfWeek)
{
countDayOfWeek++;
if (countDayOfWeek == weeksOfMonthInt)
{
endDateGMT = nextMonthFirstDay;
break;
}
} nextMonthFirstDay = nextMonthFirstDay.AddDays(1);
}
}
else
{
throw new Exception("ScheduleType is monthly, but weeksOfMonth is not between 1 and 4.");
}
}
}
else
{
throw new Exception("ScheduleType is monthly, but weeksOfMonth or daysOfWeekForMonth has multiple values.");
}
break;
default:
throw new Exception("ScheduleType is monthly, but scheduleByMonthType is " + taskTriggerType + ".");
}
break;
default:
throw new Exception("ScheduleType(" + taskTriggerType + ") is not in (Daily;Weekly;Monthly;).");
}
}
}
        private static DayOfWeek?

GetDayOfWeek(DaysOfTheWeek daysOfTheWeek)
{
DayOfWeek? dayOfWeek = null;
switch (daysOfTheWeek)
{
case DaysOfTheWeek.Sunday:
dayOfWeek = DayOfWeek.Sunday;
break;
case DaysOfTheWeek.Monday:
dayOfWeek = DayOfWeek.Monday;
break;
case DaysOfTheWeek.Tuesday:
dayOfWeek = DayOfWeek.Tuesday;
break;
case DaysOfTheWeek.Wednesday:
dayOfWeek = DayOfWeek.Wednesday;
break;
case DaysOfTheWeek.Thursday:
dayOfWeek = DayOfWeek.Thursday;
break;
case DaysOfTheWeek.Friday:
dayOfWeek = DayOfWeek.Friday;
break;
case DaysOfTheWeek.Saturday:
dayOfWeek = DayOfWeek.Saturday;
break;
default:
throw new Exception("ScheduleType is monthly, but daysOfWeek is not between Sunday and Saturday.");
} return dayOfWeek;
}

执行。就可以。

结果和方法一是一样的。

注意:方法二里。对于Monthly里。不支持选择months。自己可自行扩展。

版权声明:本文博客原创文章,博客,未经同意,不得转载。

C# Windows Schedule task此次收购task下一步执行时间的更多相关文章

  1. 【点滴积累,厚积薄发】windows schedule task的最小时间间隔是多少?

    在一些业务系统中,经常会出现一些需要定时运行的任务,业界已有很多优秀的选择,比如windows schedule task,Quartz等等.在以前在新蛋的时候用的是内部封装的JobConsole,非 ...

  2. C# Task 多任务 限制Task并发数量

    LimitedTaskScheduler: using System; using System.Collections.Concurrent; using System.Collections.Ge ...

  3. 【C# Task】理解Task中的ConfigureAwait配置同步上下文

    原文:https://devblogs.microsoft.com/dotnet/configureawait-faq/ 作者:Stephen 翻译:xiaoxiaotank 静下心来,你一定会有收获 ...

  4. Task.Run Vs Task.Factory.StartNew

    在.Net 4中,Task.Factory.StartNew是启动一个新Task的首选方法.它有很多重载方法,使它在具体使用当中可以非常灵活,通过设置可选参数,可以传递任意状态,取消任务继续执行,甚至 ...

  5. Task.Run Vs Task.Factory.StartNew z

    在.Net 4中,Task.Factory.StartNew是启动一个新Task的首选方法.它有很多重载方法,使它在具体使用当中可以非常灵活,通过设置可选参数,可以传递任意状态,取消任务继续执行,甚至 ...

  6. MapReduce作业的map task和reduce task调度参数

    MapReduce作业可以细分为map task和reduce task,而MRAppMaster又将map task和reduce task分为四种状态: 1.pending:刚启动但尚未向reso ...

  7. C# Task的使用---Task的启动

    .NET 4.0包含的新名称空间System.Threading.Tasks,它包含的类抽象出了线程功能.任务表示应完成的某个单元的工作.这个单元的工作可以在单独的线程中运行,也可以以同步的方式启动一 ...

  8. .Net4.0如何实现.NET4.5中的Task.Run及Task.Delay方法

    前言 .NET4.0下是没有Task.Run及Task.Delay方法的,而.NET4.5已经实现,对于还在使用.NET4.0的同学来说,如何在.NET4.0下实现这两个方法呢? 在.NET4.0下, ...

  9. 第八节:Task的各类Task<TResult>返回值以及通用线程的异常处理方案。

    一. Task的各种返回值-Task<TResult> PS: 在前面章节,我们介绍了Task类开启线程.线程等待.线程延续的方式,但我们并没有关注这些方式的返回值,其实他们都是有返回值的 ...

随机推荐

  1. 使用python写appium用例

    安装Python依赖 pip3.4 install nose pip3.4 install selenium pip3.4 install Appium-Python-Client 执行測试用例and ...

  2. Source Insight 光标变粗设置NotePad++光标设置

    为了更好的查看文档和代码,避免半天都找不到光标的情况,故做此说明 Source Insight 光标变粗 菜单中 Options --->Preferences --->Typing -- ...

  3. OTG驱动分析(二)

    上回介绍了OTG功能的 OTG部分驱动,本片分析OTG功能的从设备部分驱动.从设备的注冊过程和OTG的一样,首先注冊设备. 流程是: 1.定义platform_device结构. 2.定义platfo ...

  4. poj 1384 Piggy-Bank(全然背包)

    http://poj.org/problem?id=1384 Piggy-Bank Time Limit: 1000MS Memory Limit: 10000K Total Submissions: ...

  5. MVC Code First (代码优先)

    首先配置web.config <connectionStrings> <add name="BookDbContext" connectionString=&qu ...

  6. JDK5什么是新的堵塞队列线程(四)

    一. 堵塞队列与普通队列: 队列是一种主要的数据类型,其典型特征是先进先出. 堵塞队列和普通队列的差别在于: 当队列为空时.从队列中获取元素的线程会被堵塞.直到其它的线程往空的队列里插入新的元素: 当 ...

  7. apache-maven-3.2.1设备

    maven 是一个项目管理工具,并建立自己主动.本文所讲apache-maven-3.2.1设备. 它的下载: http://maven.apache.org/download.cgi ,选apach ...

  8. 系列四TortoiseSvn客户端软件

    原文:系列四TortoiseSvn客户端软件 TortoiseSvn介绍 TortoiseSvn 是 Subversion 版本控制系统的一个免费开源客户端,可以超越时间的管理文件和目录.文件保存在中 ...

  9. Spark第一个研究笔记1一片 - Spark一个简短的引论

    该公司推出的在线项目Spark拥有近1随着时间的推移.有效,Spark事实上,优秀的分布式计算平台,以提高生产力. 开始本篇笔记.此前的研究会Spark研究报告共享出来(由于篇幅的限制,它将被划分成制 ...

  10. Windows store 验证你的 URL http:// 和 https:// ms-appx:/// ms-appdata:///local

    前缀 使用 注意事项 http:// 和 https:// 联机存储的图像 这些图像可能缓存在本地,因此图像服务器可能未收到图像的请求.可以在这些 URL 中附加查询字符串.确保 Web 服务器返回原 ...