在Linux/Unix系统中,每个进程都有一个非负整型表示的唯一进程ID。虽然是唯一的,但是进程的ID可以重用。当一个进程终止后,其进程ID就可以再次使用了。大多数Linux/Unix系统采用延迟重用的算法,使得赋予新建进程ID不同于最近终止进程所使用的ID,这主要是为了防止将新进程误认为是使用同一ID的某个已终止的先前进程。本文讨论了Linux/Unix分配进程ID的方法以及源码实现。
分配进程ID的方法
在大多数Linux/Unix系统中,生成一个进程ID方法是:从0开始依次连续分配,一直到可以分配的最大的进程ID(不同的系统,这个最大值是不一样的,比如有些Linux系统是65536)。一旦到达最大值,重新从某个值(不同的系统,这个值也是不一样的,比如在Mac OS X和HP-UX系统中,这个值是100)开始依次连续查找那些还没有被使用的ID。这里分配进程ID的方法,存在潜在的安全问题。因为可以从系统获取信息或者提取进程间通信的内容。考虑到安全问题,部分系统可能用其他方法来分配进程ID,比如随机分配一个进程ID。无论用什么方法分配进程ID,系统都需要保证每个进程ID是独一无二的。
Linux系统上分配进程ID的源码实现