En informática y programación , el tiempo del sistema representa la noción que tiene un sistema informático del paso del tiempo. En este sentido, el tiempo también incluye el paso de los días en el calendario .
El tiempo del sistema se mide mediante un reloj del sistema , que normalmente se implementa como un simple recuento del número de ticks que han transcurrido desde una fecha de inicio arbitraria, llamada época . Por ejemplo, los sistemas compatibles con Unix y POSIX codifican el tiempo del sistema (" tiempo Unix ") como el número de segundos transcurridos desde el inicio de la época Unix el 1 de enero de 1970 a las 00:00:00 UT , con excepción de los segundos intercalares . Los sistemas que implementan las versiones de 32 y 64 bits de la API de Windows , como Windows 9x y Windows NT , proporcionan el tiempo del sistema como SYSTEMTIME , representado como un valor de año/mes/día/hora/minuto/segundo/milisegundos, y FILETIME , representado como un recuento del número de ticks de 100 nanosegundos desde el 1 de enero de 1601 a las 00:00:00 UT según el calendario gregoriano proléptico .
La hora del sistema se puede convertir en hora del calendario , que es una forma más adecuada para la comprensión humana. Por ejemplo, la hora del sistema Unix 1 000 000 000 segundos desde el comienzo de la época se traduce en la hora del calendario 9 de septiembre de 2001 01:46:40 UT . Las subrutinas de biblioteca que manejan tales conversiones también pueden ocuparse de los ajustes de las zonas horarias , el horario de verano (DST), los segundos intercalares y la configuración regional del usuario . Por lo general, también se proporcionan rutinas de biblioteca que convierten las horas del calendario en horas del sistema.
Muchas implementaciones que actualmente almacenan las horas del sistema como valores enteros de 32 bits sufrirán el inminente problema del año 2038. Estos valores de tiempo se desbordarán ("se quedarán sin bits") después del final de su época de tiempo del sistema, lo que provocará errores de software y hardware . Estos sistemas requerirán algún tipo de solución, similar a los esfuerzos necesarios para resolver el problema anterior del año 2000. Este también será un problema potencialmente mucho mayor para los formatos de archivos de datos existentes que contienen marcas de tiempo del sistema almacenadas como valores de 32 bits.
El tiempo de proceso está estrechamente relacionado con el tiempo del sistema y es un recuento del tiempo total de CPU consumido por un proceso en ejecución . Se puede dividir en tiempo de CPU del usuario y del sistema , que representan el tiempo empleado en ejecutar el código del usuario y el código del núcleo del sistema , respectivamente. Los tiempos de proceso son un recuento de instrucciones de CPU o ciclos de reloj y, por lo general, no tienen una correlación directa con el tiempo de ejecución .
Los sistemas de archivos realizan un seguimiento de las horas en que se crean, modifican y/o acceden a los archivos almacenando marcas de tiempo en el bloque de control de archivos (o inodo ) de cada archivo y directorio .
La mayoría de las computadoras personales de primera generación no registraban fechas y horas. Entre ellas se encontraban los sistemas que ejecutaban el sistema operativo CP/M , así como los primeros modelos de Apple II , BBC Micro y Commodore PET , entre otros. Las placas periféricas complementarias que incluían chips de reloj de tiempo real con batería de respaldo incorporada estaban disponibles para IBM PC y XT , pero IBM AT fue la primera PC ampliamente disponible que venía equipada con hardware de fecha y hora integrado en la placa base . Antes de la disponibilidad generalizada de redes de computadoras , la mayoría de los sistemas de computadoras personales que registraban la hora del sistema lo hacían solo con respecto a la hora local y no tenían en cuenta las diferentes zonas horarias .
Con la tecnología actual, la mayoría de las computadoras modernas mantienen un registro de la hora civil local, al igual que muchos otros dispositivos domésticos y personales, como videograbadoras , grabadoras de video digitales , receptores de televisión por cable , PDA , buscapersonas , teléfonos celulares , máquinas de fax , contestadores telefónicos automáticos , cámaras , videocámaras , acondicionadores de aire centrales y hornos microondas .
Los microcontroladores que funcionan dentro de sistemas integrados (como Raspberry Pi , Arduino y otros sistemas similares ) no siempre tienen hardware interno para realizar un seguimiento del tiempo. Muchos de estos sistemas controladores funcionan sin conocimiento del tiempo externo. Aquellos que requieren dicha información normalmente inicializan su tiempo base al reiniciar obteniendo el tiempo actual de una fuente externa, como un servidor de tiempo o un reloj externo, o solicitando al usuario que ingrese manualmente el tiempo actual.
El reloj del sistema se implementa normalmente como un temporizador de intervalos programable que interrumpe periódicamente la CPU, que luego comienza a ejecutar una rutina de servicio de interrupción del temporizador. Esta rutina normalmente agrega un tic al reloj del sistema (un contador simple) y maneja otras tareas de mantenimiento periódicas ( interrupción , etc.) antes de regresar a la tarea que la CPU estaba ejecutando antes de la interrupción.
Las siguientes tablas ilustran métodos para recuperar la hora del sistema en varios sistemas operativos , lenguajes de programación y aplicaciones . Los valores marcados con (*) dependen del sistema y pueden diferir entre implementaciones. Todas las fechas se dan como fechas del calendario gregoriano o gregoriano proléptico .
La resolución de la medición del tiempo de una implementación no implica la misma precisión de dichas mediciones. Por ejemplo, un sistema podría devolver la hora actual como un valor medido en microsegundos, pero en realidad podría ser capaz de discernir ticks de reloj individuales con una frecuencia de solo 100 Hz (10 ms).
En OS/2 Warp 4, la fecha y la hora pueden funcionar mucho más allá del año 2000, e incluso más allá del año 2038, y de hecho hasta el año 2079, que es el límite del reloj de tiempo real de OS/2 Warp 4.
En el componente de hoja de cálculo de Microsoft Office, el valor 0 se evalúa como la fecha 30 de diciembre de 1899 y el valor 1 como el 31 de diciembre de 1899. ... En Excel, el valor 0 se evalúa como el 0 de enero de 1900 y el valor 1 como el 1 de enero de 1900.
La nueva versión 1.9.2 es casi compatible con la 1.9.1, excepto por estos cambios: ... Se ha reimplementado el tiempo. Se ha corregido el error con el año 2038.