Unix time ( en inglés Unix time , también POSIX time ) es un sistema para describir momentos en el tiempo, adoptado en Unix y otros sistemas operativos compatibles con POSIX . Definido como el número de segundos desde la medianoche (00:00:00 UTC ) del 1 de enero de 1970 (jueves); este momento se llama "Unix Epoch" ( ing. Unix Epoch ).
El tiempo de Unix está representado por un número entero que aumenta con cada segundo que pasa sin necesidad de cálculos para determinar el año, mes, día, hora o minuto para la legibilidad humana. El tiempo moderno de Unix es consistente con UTC : la cuenta regresiva está en SI segundos . El lapso de tiempo de un día casi siempre se divide en 86.400 segundos , pero cuando se declaran los segundos bisiestos, son 86.401 segundos . Tales segundos, según el Tiempo Universal , mantienen sincronizada la duración de los días con la hora de la revolución del planeta. En tiempo Unix, los números de segundo correspondientes se repiten, es decir, los segundos bisiestos no se cuentan.
A las 00:00:00 UTC del 1 de enero de 1970 (jueves), el tiempo de Unix es cero. A partir de este momento, el número aumenta en una cierta cantidad por día. Así, por ejemplo, el 16 de septiembre de 2004 a las 00:00:00, 12677 días después del inicio del tiempo Unix, el tiempo sería 12677 × 86400 = 1095292800 , o en el caso del 17 de diciembre de 2003 a las 00:00:00, 12403 días después del inicio de la cuenta regresiva, el tiempo será el número 12403 × 86400 = 1 071 619 200 . Los cálculos también se pueden hacer a la inversa usando números negativos. Por ejemplo, la fecha 4 de octubre de 1957 00:00:00, que es 4472 días antes del inicio de la cuenta regresiva, se representa en tiempo Unix por el número −4472 × 86400 = −386380800 [1] .
Todos los días, el número que representa la hora de Unix se calcula como se describe en UTC (00:00:00Z) y aumenta exactamente 1 por segundo a partir de la medianoche . Por lo tanto, el punto en el tiempo 16-09-2004 17:55:43.54 , correspondiente a 64 543.54 segundos desde la medianoche de esta fecha, del ejemplo anterior, será representado en tiempo Unix por el número 1 095 292 800 + 64 543.54 = 1 095 357 343.54 . Para las fechas anteriores al inicio de la cuenta regresiva, el número también aumenta, es decir, con el tiempo se acerca a cero [2] .
El sistema de enteros utilizado es conveniente para comparar y almacenar fechas (la fecha y la hora en este formato ocupan solo 4 u 8 bytes ). Si necesita hacer referencia a elementos de fecha (día, mes, año), los segundos se pueden convertir a cualquier formato adecuado (y viceversa).
Los programas utilizan el tipo de entero con signo para almacenar la hora de Unix . Los números de 32 bits con signo pueden referirse a horas desde el viernes 13 de diciembre de 1901, 8:45:52 p. m. hasta el martes 19 de enero de 2038, 03:14:07 inclusive.
Para obtener la hora actual de Unix en la mayoría de los sistemas similares a Unix, puede usar el comando date +%s .
La fecha mínima en notación de 32 bits con signo es el 13 de diciembre de 1901 , 20:45:52 UTC (0x80000000, −2 147 483 648 segundos desde el 1 de enero de 1970).
Una fecha potencialmente crítica fue el 9 de septiembre de 2001 , 01:46:40 UTC , correspondiente a un gigasegundo (mil millones de segundos) de tiempo Unix, cuando la representación decimal de caracteres superó las 9 posiciones, lo que podría afectar el funcionamiento de algunas aplicaciones médicas [3] .
La principal fecha crítica desde el punto de vista del tiempo Unix es el 19 de enero de 2038 a las 03:14:08 UTC, cuando el valor de una variable de tipo que time_tcuenta el número de segundos transcurridos desde el 1 de enero de 1970 llega a 2 31 , lo que puede llevar a una interpretación errónea de este número como negativo . El conjunto de riesgos asociados a esta fecha se ha denominado problema de 2038 . Una posible solución a este problema es usar no una variable de 32 bits , sino una de 64 bits para almacenar el tiempo (que se hace en todos los sistemas operativos modernos de 64 bits), esto será suficiente para 292 mil millones de años [4] .
Los dispositivos iOS de 64 bits de Apple tienen un problema como sistema Unix: si configura la hora en un dispositivo iOS de 64 bits a la una de la mañana del 1 de enero de 1970 y reinicia el dispositivo mientras está en la zona horaria de UTC + 1:30 y más, luego de reiniciar el dispositivo, no se encenderá, el logotipo de Apple se mostrará constantemente en la pantalla. Esto sucede debido a la diferencia en las zonas horarias, es decir: si traduce la hora a la 1:00 el 1 de enero de 1970 en la zona horaria UTC +1:30 o más, entonces el contador de tiempo de Unix entra en menos, lo cual El sistema no puede entender, ya que la cuenta regresiva es de UTC, por lo que el dispositivo se congela. El dispositivo no se restaura a través de DFU, pero el problema tiene dos soluciones de otras maneras. La primera forma: esperar hasta que la batería del teléfono se agote por completo y el contador se restablezca a cero. La segunda forma: desmonte el dispositivo y desconecte la batería por un tiempo, luego vuelva a montar el dispositivo, el contador también se restablecerá a cero y el dispositivo funcionará.
El problema finalmente se resolvió en iOS 9.3.1 [5] : ahora es posible configurar la fecha en el dispositivo a partir del 1 de enero de 2001.