IPC 是 Linux 编程中一个重要的概念,IPC 有多种方式,本文主要介绍信号量集(Semaphore Sets),尽管信号量集被认为是 IPC 的一种方式,但实际上通常把信号量集用于进程间同步或者资源访问互斥,信号量集和共享内存(Shared Memory)配合使用,可以实现完美的进程间通信;Linux 既支持 UNIX SYSTEM V 的信号量集,也支持 POSIX 的信号量集,本文仅针对 SYSTEM V 信号量集;本文给出了多个具体的实例,每个实例均附有完整的源代码;本文所有实例在 Ubuntu 20.04 上编译测试通过,gcc版本号为:9.4.0;本文的实例中涉及多线程编程和信号处理等,对 Linux 编程的初学者有一些难度。
1 信号量集(Semaphore Sets)的基本概念
-
在传统的 UNIX SYSTEM V 中有三种 IPC 方法:消息队列(Message Queue)、信号量集(Semaphore Sets)和共享内存(Shared Memory);