DateTime.Now frente a DateTime.UtcNow

Resuelto Slavo asked hace 16 años • 13 respuestas

Me he estado preguntando cuáles son exactamente los principios de cómo funcionan las dos propiedades. Sé que el segundo es universal y básicamente no trata con zonas horarias, pero ¿alguien puede explicar en detalle cómo funcionan y cuál debería usarse en qué escenario?

Slavo avatar Sep 15 '08 17:09 Slavo
Aceptado

DateTime.UtcNow le indica la fecha y la hora tal como serían en el Tiempo Universal Coordinado, que también se llama zona horaria del Tiempo Medio de Greenwich, básicamente como sería si estuviera en Londres, Inglaterra, pero no durante el verano. DateTime.Now proporciona la fecha y hora tal como le aparecerían a alguien en su ubicación actual.

Recomendaría usarlo DateTime.Nowsiempre que le muestres una fecha a un ser humano; de esa manera se sentirán cómodos con el valor que ven; es algo que pueden comparar fácilmente con lo que ven en su reloj. Úselo DateTime.UtcNowcuando desee almacenar fechas o utilizarlas para cálculos posteriores de esa manera (en un modelo cliente-servidor) sus cálculos no se confundan con clientes en diferentes zonas horarias de su servidor o entre sí.

Blair Conrad avatar Sep 15 '2008 11:09 Blair Conrad

Es realmente bastante simple, así que creo que depende de cuál sea tu audiencia y dónde viva.

Si no usa Utc, debe conocer la zona horaria de la persona a la que le está mostrando fechas y horas; de lo contrario, le dirá que algo sucedió a las 3 p. m. en el horario del sistema o del servidor, cuando en realidad sucedió a las 5 p. m., donde resulta que viven.

Lo usamos DateTime.UtcNowporque tenemos una audiencia web global y porque preferiría no molestar a cada usuario para que complete un formulario que indique en qué zona horaria vive.

También mostramos tiempos relativos (hace 2 horas, hace 1 día, etc.) hasta que la publicación envejece lo suficiente como para que la hora sea "la misma" sin importar en qué lugar de la Tierra viva.

Jeff Atwood avatar Sep 15 '2008 11:09 Jeff Atwood

Tenga en cuenta también la diferencia de rendimiento; DateTime.UtcNowes alrededor de 30 veces más rápido que DateTime.Now, porque internamente DateTime.Nowse están realizando muchos ajustes de zona horaria (puede verificar esto fácilmente con Reflector).

Por lo tanto, NO lo use DateTime.Nowpara mediciones de tiempo relativo.

Magnus Krisell avatar Feb 21 '2009 13:02 Magnus Krisell

Un concepto principal que hay que entender en .NET es que ahora está en todo el mundo sin importar en qué zona horaria te encuentres. Entonces, si cargas una variable con o , la asignación es idéntica.* Tu objeto sabe en qué zona horaria te encuentras y lo tiene en cuenta independientemente de la tarea.DateTime.NowDateTime.UtcNowDateTime

La utilidad de DateTime.UtcNowresulta útil al calcular fechas a través de los límites del horario de verano. Es decir, en lugares que participan en el horario de verano, a veces hay 25 horas desde el mediodía hasta el mediodía del día siguiente, y a veces hay 23 horas entre el mediodía y el mediodía del día siguiente. Si desea determinar correctamente la cantidad de horas de la hora A y la hora B, primero debe traducir cada una a sus equivalentes UTC antes de calcular el TimeSpan.

Esto está cubierto en una publicación de blog que escribí que explica con más detalle TimeSpane incluye un enlace a un artículo de MS aún más extenso sobre el tema.

*Aclaración: Cualquiera de las asignaciones almacenará la hora actual. Si cargara dos variables, una vía DateTime.Now()y la otra vía, DateTime.UtcNow()la TimeSpandiferencia entre las dos sería de milisegundos (si ambas están normalizadas vía ToUniversalTime()), no horas, suponiendo que se encuentre en una zona horaria alejada de GMT. Como se indica a continuación, imprimir sus Stringvalores mostraría cadenas diferentes.

Carl Camera avatar Sep 16 '2008 20:09 Carl Camera