sleep (command)

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

sleep
The sleep command
The sleep command
Developer(s)AT&T Bell Laboratories, Microsoft, Microware, Trane Francks
Initial releaseNovember 1973; 46 years ago (1973-11)
Operating systemUnix, Unix-like, V, Plan 9, Inferno, OS-9, MSX-DOS, FreeDOS, Windows, KolibriOS, IBM i
PlatformCross-platform
TypeCommand
Licensecoreutils: GPLv3+
FreeDOS: GPLv2

In computing, sleep is a command in Unix, Unix-like and other operating systems that suspends program execution for a specified time.

Overview[edit]

The sleep instruction suspends the calling process for at least the specified number of seconds (the default), minutes, hours or days.

sleep for Unix-like systems is part of the X/Open Portability Guide since issue 2 of 1987. It was inherited into the first version of POSIX and the Single Unix Specification.[1] It first appeared in Version 4 Unix.[2]

The version of sleep bundled in GNU coreutils was written by Jim Meyering and Paul Eggert.[3] The command is also available in the OS-9 shell,[4] in the KolibriOS Shell,[5] and part of the FreeDOS Package group Utilities.[6] The FreeDOS version was developed by Trane Francks and is licensed under the GPL.[7]

A sleep command is also part of ASCII's MSX-DOS2 Tools for MSX-DOS version 2.[8]

In PowerShell, sleep is a predefined command alias for the Start-Sleep cmdlet which serves the same purpose.[9] Microsoft also provides a sleep resource kit tool for Windows which can be used in batch files or the command prompt to pause the execution and wait for some time.[10] Another native version is the timeout command which is part of current versions of Windows.[11]

The sleep command has also been ported to the IBM i operating system.[12]

Usage[edit]

 sleep number

Where number is an integer[13] number to indicate the time period in seconds. Some implementations support floating point numbers.

Options[edit]

None.

Examples[edit]

 sleep 30

Causes the current terminal session to wait 30 seconds.

 sleep 18000

Causes the current terminal session to wait 5 hours

GNU sleep[edit]

 sleep 3h ; mplayer foo.mp3

Wait 3 hours then play foo.mp3

Note that sleep 5h30m and sleep 5h 30m are illegal since sleep takes only one value and unit as argument. However, sleep 5.5h (a floating point[14]) is allowed. Consecutive executions of sleep can also be used.

 sleep 5h; sleep 30m

Sleep 5 hours, then sleep another 30 minutes.

The GNU Project's implementation of sleep (part of coreutils) allows the user to pass an arbitrary floating point[14] or multiple arguments, therefore sleep 5h 30m (a space separating hours and minutes is needed) will work on any system which uses GNU sleep, including Linux.

Possible uses for sleep include scheduling tasks and delaying execution to allow a process to start, or waiting until a shared network connection most likely has few users to wget a large file.

See also[edit]

References[edit]

  1. ^ sleep – Commands & Utilities Reference, The Single UNIX Specification, Issue 7 from The Open Group
  2. ^ sleep(1) – FreeBSD General Commands Manual
  3. ^ "sleep(1): delay for specified amount of time - Linux man page". linux.die.net.
  4. ^ Paul S. Dayan (1992). The OS-9 Guru - 1 : The Facts. Galactic Industrial Limited. ISBN 0-9519228-0-7.
  5. ^ "Shell - KolibriOS wiki". wiki.kolibrios.org.
  6. ^ "ibiblio.org FreeDOS Group -- Utilities". www.ibiblio.org.
  7. ^ "ibiblio.org FreeDOS Package -- sleep (Unix-like)". www.ibiblio.org.
  8. ^ "MSX-DOS2 Tools User's Manual - MSX-DOS2 TOOLS ユーザーズマニュアル". April 1, 1993 – via Internet Archive.
  9. ^ "Start-Sleep (Microsoft.PowerShell.Utility) - PowerShell". docs.microsoft.com.
  10. ^ [1][dead link]
  11. ^ "Timeout". docs.microsoft.com.
  12. ^ IBM. "IBM System i Version 7.2 Programming Qshell" (PDF). Retrieved 2020-09-05.
  13. ^ "sleep(3): sleep for specified number of seconds - Linux man page". linux.die.net. Retrieved 19 April 2018.
  14. ^ a b "GNU Coreutils: sleep invocation". www.gnu.org. Retrieved 19 April 2018.

External links[edit]