In computing, the process identifier (normally referred to as the process ID or just PID) is a number used by most operating system kernels — such as that of UNIX, macOS or Microsoft Windows — to uniquely identify an active process. This number may be used as a parameter in various function calls, allowing processes to be manipulated, such as adjusting the process's priority or killing it altogether.
In Unix-like operating systems, new processes are created by the
fork() system call. The PID is returned to the parent enabling it to refer to the child in further function calls. The parent may, for example, wait for the child to terminate with the
waitpid() function, or terminate the process with
There are two tasks with specially distinguished process IDs: swapper or sched has process ID 0 and is responsible for paging, and is actually part of the kernel rather than a normal user-mode process. Process ID 1 is usually the init process primarily responsible for starting and shutting down the system. Originally, process ID 1 was not specifically reserved for init by any technical measures: it simply had this ID as a natural consequence of being the first process invoked by the kernel. More recent Unix systems typically have additional kernel components visible as 'processes', in which case PID 1 is actively reserved for the init process to maintain consistency with older systems.
Process IDs are usually allocated on a sequential basis, beginning at 0 and rising to a maximum value which varies from system to system. Once this limit is reached, allocation restarts at 300 and again increases. In macOS and HP-UX, allocation restarts at 100. However, for this and subsequent passes any PIDs still assigned to processes are skipped. Some consider this to be a potential security vulnerability in that it allows information about the system to be extracted, or messages to be covertly passed between processes. As such, implementations that are particularly concerned about security may choose a different method of PID assignment. On some systems, like MPE/iX, the lowest available PID is used, sometimes in an effort to minimize the number of process information kernel pages in memory.
The current process ID is provided by a
getpid() system call, or as a variable
$$ in shell. The process ID of a parent process is obtainable by a
getppid() system call.
Under Microsoft Windows operating systems, one can get the current process' ID using
GetCurrentProcessId() API, and ID of other processes using
GetProcessId() API. Internally, process ID is called a client ID, and is allocated from the same namespace as thread IDs, so these two never overlap. The so-called System Idle Process is given process ID 0, and System Process is given process ID 4. In some versions of Windows, process and thread identifiers are all multiples of 4, but it is not part of the specification.
- comp.unix.aix Frequently Asked Questions, retrieved 2008-07-21
- "proc - process information pseudo-filesystem", Linux Programmer's Manual, retrieved 2009-12-28
- GetCurrentProcessId Function, Windows Developer Center, retrieved 2009-05-20
- ProcessId Function, Windows Developer Center, retrieved 2011-03-05
- Chen, Raymond (2008-02-28). "Why are process and thread IDs multiples of four?". The Old New Thing. MSDN Blogs. Retrieved 2016-11-11.