System time explained

In computer science and computer programming, system time represents a computer system's notion of the passage of time. In this sense, time also includes the passing of days on the calendar.

System time is measured by a system clock, which is typically implemented as a simple count of the number of ticks that have transpired since some arbitrary starting date, called the epoch. For example, Unix and POSIX-compliant systems encode system time ("Unix time") as the number of seconds elapsed since the start of the Unix epoch at 1 January 1970 00:00:00 UT, with exceptions for leap seconds. Systems that implement the 32-bit and 64-bit versions of the Windows API, such as Windows 9x and Windows NT, provide the system time as both, represented as a year/month/day/hour/minute/second/milliseconds value, and, represented as a count of the number of 100-nanosecond ticks since 1 January 1601 00:00:00 UT as reckoned in the proleptic Gregorian calendar.

System time can be converted into calendar time, which is a form more suitable for human comprehension. For example, the Unix system time seconds since the beginning of the epoch translates into the calendar time 9 September 2001 01:46:40 UT. Library subroutines that handle such conversions may also deal with adjustments for time zones, daylight saving time (DST), leap seconds, and the user's locale settings. Library routines are also generally provided that convert calendar times into system times.

Many implementations that currently store system times as 32-bit integer values will suffer from the impending Year 2038 problem. These time values will overflow ("run out of bits") after the end of their system time epoch, leading to software and hardware errors. These systems will require some form of remediation, similar to efforts required to solve the earlier Year 2000 problem. This will also be a potentially much larger problem for existing data file formats that contain system timestamps stored as 32-bit values.

Other time measurements

Closely related to system time is process time, which is a count of the total CPU time consumed by an executing process. It may be split into user and system CPU time, representing the time spent executing user code and system kernel code, respectively. Process times are a tally of CPU instructions or clock cycles and generally have no direct correlation to wall time.

File systems keep track of the times that files are created, modified, and/or accessed by storing timestamps in the file control block (or inode) of each file and directory.

History

Most first-generation personal computers did not keep track of dates and times. These included systems that ran the CP/M operating system, as well as early models of the Apple II, the BBC Micro, and the Commodore PET, among others. Add-on peripheral boards that included real-time clock chips with on-board battery back-up were available for the IBM PC and XT, but the IBM AT was the first widely available PC that came equipped with date/time hardware built into the motherboard. Prior to the widespread availability of computer networks, most personal computer systems that did track system time did so only with respect to local time and did not make allowances for different time zones.

With current technology, most modern computers keep track of local civil time, as do many other household and personal devices such as VCRs, DVRs, cable TV receivers, PDAs, pagers, cell phones, fax machines, telephone answering machines, cameras, camcorders, central air conditioners, and microwave ovens.

Microcontrollers operating within embedded systems (such as the Raspberry Pi, Arduino, and other similar systems) do not always have internal hardware to keep track of time. Many such controller systems operate without knowledge of the external time. Those that require such information typically initialize their base time upon rebooting by obtaining the current time from an external source, such as from a time server or external clock, or by prompting the user to manually enter the current time.

Implementation

The system clock is typically implemented as a programmable interval timer that periodically interrupts the CPU, which then starts executing a timer interrupt service routine. This routine typically adds one tick to the system clock (a simple counter) and handles other periodic housekeeping tasks (preemption, etc.) before returning to the task the CPU was executing before the interruption.

Retrieving system time

UTC

The following tables illustrate methods for retrieving the system time in various operating systems, programming languages, and applications. Values marked by (*) are system-dependent and may differ across implementations. All dates are given as Gregorian or proleptic Gregorian calendar dates.

The resolution of an implementation's measurement of time does not imply the same precision of such measurements. For example, a system might return the current time as a value measured in microseconds, but actually be capable of discerning individual clock ticks with a frequency of only 100 Hz (10 ms).

Operating systems

Operating systemCommand or functionResolutionEpoch or range
Android1 ms1 January 1970
BIOS (IBM PC)[1] 54.9254 ms
18.2065 Hz
Midnight of the current day
[2] 1 sMidnight of the current day
[3] 1 day1 January 1980 to 31 December 1999 or 31 December 2079 (system dependent)
CP/M PlusSystem Control Block:[4]
, Days since 31 December 1977
, Hour (BCD)
, Minute (BCD)
, Second (BCD)
1 s31 December 1977 to 5 June 2157
BDOS function > :[5]
, Days since 1 January 1978
, Hour (BCD)
, Minute (BCD)
, Second (BCD)
DOS (Microsoft)
10 ms<-- DL returns 1/100 of a second, so resolution is 10 ms; though accuracy is 55 ms. Also the FAT filesystem stores timestamps with 2 s resolution, except for create date, which is stored in 10 ms -->1 January 1980 to 31 December 2099
[6]
[7]
iOS (Apple)[8] < 1 ms1 January 2001 ±10,000 years
macOS[9] < 1 ms[10] [11] 1 January 2001 ±10,000 years
OpenVMS100 ns[12] 17 November 1858 to 31 July 31,086[13]
1 μs[14] 1 January 1970 to 7 February 2106[15]
1 ns
z/OS[16] 2-12 μs
244.14 ps
1 January 1900 to 17 September 2042 UT[17]
1 January 1900 to AD 36,765[18]
Unix, POSIX
(see also C date and time functions)

1 s(*)
1 January 1970 (to 19 January 2038 prior to Linux 5.9) to 2 July 2486 (Since Linux 5.10)
1 January 1970 to 4 December AD 292,277,026,596
1 μs
1 ns
OS/210 ms1 January 1980 to 31 December 2079[19]
Windows1 ms1 January 1601 to 14 September 30828, 02:48:05.4775807
100 ns

Programming languages and applications

Language/ApplicationFunction or variableResolutionEpoch or range
Ada100 μs to
20 ms (*)
1 January 1901 to 31 December 2099 (*)
AWK1 s(*)
BASIC, True BASIC,
,
1 s(*)
Business BASIC, 0.1 s(*)
C (see C date and time functions)1 s (*)[20] (*)
C++
1 s (*)
1 ns (C++11, OS dependent)
(*)
C#[21]
[22]
100 ns[23] 1 January 0001 to 31 December 9999
CICS1 ms1 January 1900
COBOL1 s1 January 1601
Common Lisp1 s1 January 1900
Delphi (Borland)
1 ms
(floating point)
1 January 1900
Delphi
(Embarcadero Technologies)[24]
[25] 1 ms0/0/0000 0:0:0:000 to
12/31/9999 23:59:59:999 [sic]
[26] (alias for)
[27] 0/0/0000 0:0:0:000 to
12/31/9999 0:0:0:000 [sic]
[28]
[29]
[30]
[31] 1 s0/0/0000 0:0:0:000 to
12/31/9999 23:59:59:000 [sic]
[32] 1 day1 to 7
[33] 1 year(*)
Emacs Lisp1 μs (*)1 January 1970
Erlang, [34] OS dependent, e.g. on Linux 1ns1 January 1970
Excel?0 January 1900[35]
Fortran
(*)[36] [37] 1 January 1970
1 μs
Go1 ns1 January 0001
Haskell1 ps (*)1 January 1970 (*)
1 ps (*)17 November 1858 (*)
Java
1 ms1 January 1970
[38] 1 nsarbitrary
[39] 1 nsarbitrary[40]
JavaScript, TypeScript
1 ms1 January 1970
Matlab1 s0 January 0000[41]
MUMPS (short for )1 s31 December 1840
LabVIEW1 ms00:00:00.000 1 January 1904
1 ms00:00:00.000 1 January 1904
Objective-C< 1 ms[42] 1 January 2001 ±10,000 Years
OCaml1 s1 January 1970
1 μs
Extended Pascal1 s(*)
Turbo Pascal
10 ms(*)
Perl1 s1 January 1970
[43] 1 μs
PHP
1 s1 January 1970
1 μs
PureBasic1 s1 January 1970 to 19 January 2038
Python1 μs (*)1 January 1970
RPG,
,
1 s1 January 0001 to 31 December 9999
, 1 μs
Ruby[44] 1 μs (*)1 January 1970
(to 19 January 2038 prior to Ruby 1.9.2[45])
Scheme[46] 1 s1 January 1900
Smalltalk
1 s
1 μs
1 s
1 January 1901 (*)


SQL or
or
or
or
3 ms1 January 1753 to 31 December 9999 (*)
60 s1 January 1900 to 6 June 2079
Standard ML1 μs (*)1 January 1970 (*)
TCL1 s1 January 1970
1 ms
1 μs
1 μs (*)(*)
Windows PowerShell[47] [48] 100 ns 1 January 0001 to 31 December 9999

Visual Basic .NET
100 ns 1 January 0001 to 31 December 9999

Notes

  1. Web site: Ralf D. Brown. Ralf D. Brown. Int 0x1A, AH=0x00. Ralf Brown's Interrupt List. 2000.
  2. Web site: Ralf D. Brown. Ralf D. Brown. Int 0x1A, AH=0x02. Ralf Brown's Interrupt List. 2000.
  3. Web site: Ralf D. Brown. Ralf D. Brown. Int 0x1A, AH=0x04. Ralf Brown's Interrupt List. 2000.
  4. Web site: CP/M Plus (CP/M Version 3.0) Operating System Guide.
  5. Web site: BDOS system calls.
  6. Web site: Ralf D. Brown. Ralf D. Brown. Int 0x21, AH=0x2c. Ralf Brown's Interrupt List. 2000.
  7. Web site: Ralf D. Brown. Ralf D. Brown. Int 0x21, AH=0x2a. Ralf Brown's Interrupt List. 2000.
  8. Web site: Time Utilities Reference. iOS Developer Library. 2007.
  9. Web site: Time Utilities Reference. Mac OS X Developer Library. 2007.
  10. Web site: Time Utilities - Foundation . 6 July 2022 . Apple Developer Documentation.
  11. The Apple Developer Documentation is not clear on the precision & range of CFAbsoluteTime/CFTimeInterval, except in the CFRunLoopTimerCreate documentation which refers to 'sub-millisecond at most' precision. However, the similar type NSTimeInterval appears to be interchangeable, and has the precision and range listed.
  12. Book: VAX/VMS Internals and Data Structures, Version 5.2. 978-1555580599. Ruth E. Goldenberg. Lawrence J. Kenah. Denise E. Dumas. Digital Press. 1991.
  13. Web site: Why is Wednesday, November 17, 1858 the base time for OpenVMS (VAX VMS)? . 2020-01-08 . 1997-07-24 . . https://web.archive.org/web/19970724202734/https://www.slac.stanford.edu/~rkj/crazytime.txt . 1997-07-24 . dmy-all . live.
  14. Web site: VSI C Run-Time Library Reference Manual for OpenVMS Systems. November 2020. VSI. 2021-04-17.
  15. Web site: OpenVMS and the year 2038. HP. 2021-04-17.
  16. Book: z/Architecture Principles of Operation. Poughkeepsie, New York. International Business Machines. 2007.
  17. IBM intends to extend the date range on future systems beyond 2042. z/Architecture Principles of Operation, (Poughkeepsie, New York:International Business Machines, 2007) 1-15, 4-45 to 4-47.
  18. Web site: Expanded 64-bit time values. IBM. 2021-04-18.
  19. Web site: On OS/2 Warp 4, date and time can both operate well beyond the year 2000, and even well beyond the year 2038, and in fact up to the year 2079, which is the limit for OS/2 Warp 4's real-time clock.. The 32-bit Command Interpreter. Jonathan de Boyne Pollard.
  20. The C standard library does not specify any specific resolution, epoch, range, or datatype for system time values. The C++ library encompasses the C library, so it uses the same system time implementation as C.
  21. Web site: DateTime.Now Property. Microsoft Docs.
  22. Web site: DateTime.UtcNow Property. Microsoft Docs.
  23. Web site: DateTime.Ticks Property. Microsoft Docs.
  24. Web site: Date and Time Support. Embarcadero Developer Network. 2013.
  25. Web site: System.SysUtils.Time. Embarcadero Developer Network. 2013.
  26. Web site: System.SysUtils.GetTime. Embarcadero Developer Network. 2013.
  27. Web site: System.SysUtils.Date. Embarcadero Developer Network'. 2013.
  28. Web site: System.DateUtils.Today. Embarcadero Developer Network. 2013.
  29. Web site: System.DateUtils.Tomorrow. Embarcadero Developer Network. 2013.
  30. Web site: System.DateUtils.Yesterday. Embarcadero Developer Network. 2013.
  31. Web site: System.SysUtils.Now. Embarcadero Developer Network. 2013.
  32. Web site: System.SysUtils.DayOfWeek. Embarcadero Developer Network. 2013.
  33. Web site: System.SysUtils.CurrentYear. Embarcadero Developer Network. 2013.
  34. Web site: Time and Time Correction in Erlang. www.erlang.org.
  35. Web site: In the Microsoft Office Spreadsheet Component, the value 0 evaluates to the date December 30, 1899 and the value 1 evaluates to December 31, 1899. ... In Excel, the value 0 evaluates to January 0, 1900 and the value 1 evaluates to January 1, 1900.. XL2000: Early Dates on Office Spreadsheet Component Differ from Excel. Microsoft Support. 2003. https://web.archive.org/web/20071024010448/http://support.microsoft.com/kb/205719. 24 October 2007.
  36. Web site: SYSTEM_CLOCK. Intel Fortran Compiler 19.0 Developer Guide and Reference. 29 April 2019. 23 July 2019.
  37. Web site: SYSTEM_CLOCK — Time function. The GNU Fortran Compiler. 27 October 2011.
  38. Web site: System.nanoTime method. Java Platform, Standard Edition 6: API Specification. 2015. 23 July 2019.
  39. Web site: Clock.systemUTC and other methods. Java Platform, Standard Edition 8: API Specification. 2014. 15 January 2015.
  40. Web site: JSR-310 Java Time System. Java Platform, Standard Edition 8: API Specification. 2014. 15 January 2015.
  41. Web site: Matlab Help.
  42. Web site: NSTimeInterval - Foundation. Apple Developer Documentation.
  43. Douglas Wegscheild, R. Schertler, and Jarkko Hietaniemi, Web site: Time::HiRes. CPAN - Comprehensive Perl Archive Network. 2011. 27 October 2011.
  44. Web site: Time class. Ruby-Doc.org: Help and documentation for the Ruby programming language. Scottsdale, AZ. James Britt. Neurogami. 27 October 2011.
  45. Web site: Ruby 1.9.2 is released. Yugui. 18 August 2010. The new 1.9.2 is almost compatible with 1.9.1, except these changes: ... Time is reimplemented. The bug with year 2038 is fixed..
  46. Web site: MIT/GNU Scheme 9.2: 15.5 Date and Time .
  47. Web site: Using the Get-Date Cmdlet . Microsoft Docs . 23 July 2019.
  48. Web site: Windows PowerShell Tip of the Week – Formatting Dates and Times . Microsoft Docs . 23 July 2019.

External links