ConvertTimeFromUtc()和ToUniversalTime()是否处理​​DST?

如果夏令时生效,并且日期对象已保存到数据库中(UTC格式),您将检索该数据库以在视图中显示它(例如asp.net-mvc的视图)。

你通过使用这种方法来做到这一点:

 public static DateTime ConvertToLocalTimeFromUtcTime(DateTime utcDate, string timeZoneId) { TimeZoneInfo localZone = TimeZoneInfo.FindSystemTimeZoneById(timeZoneId); DateTime localTime = TimeZoneInfo.ConvertTimeFromUtc(utcDate, localZone); if (localZone.IsDaylightSavingTime(localTime)) localTime = localTime.AddHours(1); // is this needed !? return localTime; } 

问题是, TimeZoneInfo.ConvertTimeFromUtc()处理DST,或者您是否必须自己检查并向日期对象添加或减去X小时?

通过使用ToUniversalTime()将日期对象转换为UTC格式来将日期对象持久化到数据库时的相同问题。

是。 只要您定位的时区使用夏令时, ConvertTimeFromUtc就会自动处理夏令时调整。

从MSDN文档 :

执行转换时, ConvertTimeFromUtc方法应用destinationTimeZone时区中有效的任何调整规则。

您不应该尝试在转换中添加额外的小时。 这会给你一个不正确的翻译。

关于DateTime.ToUniversalTime ,它确实考虑了DST,但要小心这个方法。 它假定输入值在计算机的本地时区。 如果您只需要使用DateTime.SpecifyKind标记它,那么请改用DateTime.SpecifyKind