Unix date command

In computing, system time represents a computer system's notion of a point in time.

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 SYSTEMTIME, represented as a year/month/day/hour/minute/second/milliseconds value, and FILETIME, 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 1000000000 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 problems such as 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 the time taken by 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 the current system time

17 April 2026 03:35:01 UTC The Wikipedia system time when this page was last generated. → Purge this page, and update this counter.

The following tables illustrate methods for retrieving the current 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
Androidjava.lang.System.currentTimeMillis()1 ms1 January 1970
BIOS (IBM PC)INT 1Ah, AH=00h54.9254 ms 18.2065 HzMidnight of the current day
INT 1Ah, AH=02h1 sMidnight of the current day
INT 1Ah, AH=04h1 day1 January 1980 to 31 December 1999 or 31 December 2079 (system dependent)
CP/M PlusSystem Control Block: scb$base+58h, Days since 31 December 1977 scb$base+5Ah, Hour (BCD) scb$base+5Bh, Minute (BCD) scb$base+5Ch, Second (BCD)1 s31 December 1977 to 5 June 2157
BDOS function 69h> (T_GET): word, Days since 1 January 1978 byte, Hour (BCD) byte, Minute (BCD) byte, Second (BCD)
DOS (Microsoft)C:\> DATE C:\> TIME10 ms1 January 1980 to 31 December 2099
INT 21h, AH=2Ch SYSTEM TIME INT 21h, AH=2Ah SYSTEM DATE
macOS, iOS, iPadOS, tvOS, watchOS, visionOS (Apple)CFAbsoluteTimeGetCurrent()< 1 ms1 January 2001 ±10,000 years
OpenVMSSYS$GETTIM()100 ns17 November 1858 to 31 July 31,086
()1 μs1 January 1970 to 7 February 2106
()1 ns
z/OSSTCK2−12 μs 244.14 ps1 January 1900 to 17 September 2042 UT
STCKE1 January 1900 to AD 36,765
Unix, POSIX (see also C date and time functions)$date time()1 s(*) 32-bit time_t: 1 January 1970 to 19 January 2038 64-bit time_t: 1 January 1970 to 4 December AD 292,277,026,596
()1 μs
()1 ns
OS/2DosGetDateTime()10 ms1 January 1980 to 31 December 2079
WindowsGetSystemTime()1 ms1 January 1601 to 14 September 30828, 02:48:05.4775807
GetSystemTimeAsFileTime()100 ns
GetSystemTimePreciseAsFileTime()

Programming languages and applications

Language/ApplicationFunction or variableResolutionEpoch or range
AdaAda.Calendar.Clock100 μs to 20 ms (*)1 January 1901 to 31 December 2099 (*)
AWKsystime()1 s(*)
BASIC, True BASICDATE, DATE$ TIME, TIME$1 s(*)
Business BASICDAY, TIM0.1 s(*)
C (see C date and time functions)time()1 s (*)(*)
C++std::time() std::chrono::system_clock::now()1 s (*) 1 ns (C++11, OS dependent)(*)
C#System.DateTime.Now System.DateTime.UtcNow100 ns1 January 0001 to 31 December 9999
CICSASKTIME1 ms1 January 1900
COBOLFUNCTION CURRENT-DATE1 s1 January 1601
Common Lisp(get-universal-time)1 s1 January 1900
Delphi (Borland)date time1 ms (floating point)1 January 1900
Delphi (Embarcadero Technologies)System.SysUtils.Time1 ms0/0/0000 0:0:0:000 to 12/31/9999 23:59:59:999 [sic]
System.SysUtils.GetTime (alias for System.SysUtils.Time)
System.SysUtils.Date0/0/0000 0:0:0:000 to 12/31/9999 0:0:0:000 [sic]
System.DateUtils.Today
System.DateUtils.Tomorrow
System.DateUtils.Yesterday
System.SysUtils.Now1 s0/0/0000 0:0:0:000 to 12/31/9999 23:59:59:000 [sic]
System.SysUtils.DayOfWeek1 day1 to 7
System.SysUtils.CurrentYear1 year(*)
Emacs Lisp(current-time)1 μs (*)1 January 1970
Erlang,OS dependent, e.g. on Linux 1ns1 January 1970
Exceldate()?0 January 1900
FortranDATE_AND_TIME SYSTEM_CLOCK(*)1 January 1970
CPU_TIME1 μs
Gotime.Now()1 ns1 January 0001
HaskellTime.getClockTime1 ps (*)1 January 1970 (*)
Data.Time.getCurrentTime1 ps (*)17 November 1858 (*)
Javajava.util.Date() System.currentTimeMillis()1 ms1 January 1970
System.nanoTime()1 nsarbitrary
Clock.systemUTC()1 nsarbitrary
JavaScript, TypeScript(new Date()).getTime() Date.now()1 ms1 January 1970
JuliaDates.now()1 ms1 January 0000
Matlabnow1 s0 January 0000
MUMPS$H (short for $HOROLOG)1 s31 December 1840
LabVIEWTick Count1 ms00:00:00.000 1 January 1904
Get Date/Time in Seconds1 ms00:00:00.000 1 January 1904
Objective-C[NSDate timeIntervalSinceReferenceDate]< 1 ms1 January 2001 ±10,000 Years
OCamlUnix.time()1 s1 January 1970
Unix.gettimeofday()1 μs
Extended PascalGetTimeStamp()1 s(*)
Turbo PascalGetTime() GetDate()10 ms(*)
Perltime()1 s1 January 1970
Time::HiRes::time1 μs
PHPtime() mktime()1 s1 January 1970
microtime()1 μs
PureBasicDate()1 s1 January 1970 to 19 January 2038
Pythondatetime.now().timestamp()1 μs (*)1 January 1970
RPGCURRENT(DATE), %DATE CURRENT(TIME), %TIME1 s1 January 0001 to 31 December 9999
CURRENT(TIMESTAMP), %TIMESTAMP1 μs
RubyTime.now()1 μs (*)1 January 1970 (to 19 January 2038 prior to Ruby 1.9.2)
Scheme(get-universal-time)1 s1 January 1900
SmalltalkTime microsecondClock (VisualWorks)1 s (ANSI) 1 μs (VisualWorks) 1 s (Squeak)1 January 1901 (*)
Time totalSeconds (Squeak)
SystemClock ticksNowSinceSystemClockEpoch (Chronos)
SQLCURDATE() or CURRENT DATE CURTIME() or CURRENT TIME GETDATE() or GETUTCDATE() NOW() or CURRENT TIMESTAMP SYSDATE()3 ms1 January 1753 to 31 December 9999 (*)
1 min1 January 1900 to 6 June 2079
Standard MLTime.now()1 μs (*)1 January 1970 (*)
Tcl[clock seconds]1 s1 January 1970
[clock milliseconds]1 ms
[clock microseconds]1 μs
[clock clicks]1 μs (*)(*)
Windows PowerShellGet-Date100 ns1 January 0001 to 31 December 9999
[DateTime]::Now [DateTime]::UtcNow
Visual Basic .NETSystem.DateTime.Now System.DateTime.UtcNow100 ns1 January 0001 to 31 December 9999

See also

Notes

External links

  • , J. R. Stockton (retrieved 3 December 2015)
  • (C++)
  • (C++)
  • (Smalltalk)
  • , The Joda Date/Time Library (Java)
  • 2009-02-19 at the Wayback Machine (Perl)
  • (Ruby)