DateTimeOffset如何处理夏令时?

我知道DateTimeOffset存储UTC日期/时间和偏移量。 我也从MSDN博客文章中了解到DateTimeOffset应该用于“使用夏令时”。

我正在努力理解的是DateTimeOffset“如何工作夏令时”。 我的理解,很少有,是夏令时是一个政治决定,不能从纯粹的抵消推断出来。 如果它只存储一个偏移量,那么这个结构对DST是否友好呢?

我认为可能有一种方法可以将TimeZoneInfo类与DateTimeOffset结合使用。 我该怎么办?

最后,有什么更好的方法可以实现以下目标吗?

(我看过Jon Skeet关于Noda-Time的一些post,但我认为它尚未准备好生产,我不知道它是否能很好地融入我们现有的解决方案)。

这是我们的场景。 该服务器是出于在英国时间运行的不幸遗留原因。 我们的客户开始从澳大利亚投入运营,其中有多个时区。 其他国家可以随时投入使用。

我们有一个基于Hardcodet调度程序的调度程序 (使用DateTimeOffset)。 它工作得很好。 但是,在我们的数据库中,我们只存储足够的数据来构造DateTime对象(见下文),在我们的子类和管道代码中我们只使用DateTime,因为最初我们只支持英国用户。

该调度程序负责固定和动员工厂设备。 因此,计划的事件在用户的DST调整的本地时间运行至关重要。

用户在我们的网站上输入时间表; 目前,它作为星期几,小时和分钟存储在数据库中。 当读取数据时,我们为下一天,小时和分钟的出现创建一个DateTime对象。 我可以自由地更改db结构以另外存储偏移量或时区。

当该日期和时间到达时,调度程序发送命令(并重试一段时间)。 然后它会在下周的同一天和时间再次运行(尽管该服务实际上已经被回收,代码将再次运行)。

我需要实现的是使用从Hardcodet子类调度的调度程序在该时区调整的本地日期和时间触发调度事件。 如果DateTimeOffset确实是DST感知的,那么我需要做的就是存储一个偏移量并改变我们的管道代码以使用这个结构,但我得到的印象并不是那么简单。 (我们或许可以从工厂的GPS位置获取当前时区,但这是另一天的讨论:))。

DateTimeOffset本身并不真正支持DST,但TimeZoneInfo是。 DateTimeOffset表示固定的即时时间 – 因此您可以通过时区感知到达DateTimeOffset 。 换句话说,如果我现在要求在英国使用DateTimeOffset ,我最终会得到与UTC相差+1小时的内容。 如果我在12月份在英国要求DateTimeOffset一段时间,我最终会得到一个与UTC相差0小时的东西。

如果您更改数据库以包含偏移量, 并且您从用户选择的DateTime (应该是类型“未指定”)及其时区创建DateTimeOffset ,那么这应该为您提供考虑DST的正确偏移量。

但要注意的一件事是:如果我现在安排一些“2年时间”并且你现在确定了偏移量,那么将来这种偏移可能是不正确的 – 例如,政府可能会在DST适用时改变,显然这是不会改变数据库中存储的内容。