Linux进程间的通信方式之共享内存 + 信号量
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
#include <sys/shm.h>
// 信号量操作的宏定义
#define P(semaphore) semop(semaphore, &ps, 1)
#define V(semaphore) semop(semaphore, &vs, 1)
union semun {
int val; /* Value for SETVAL */
struct semid_ds *buf; /* Buffer for IPC_STAT, IPC_SET */
unsigned short *array; /* Array for GETALL, SETALL */
struct seminfo *__buf; /* Buffer for IPC_INFO (Linux-specific) */
};
int main() {
key_t key = ftok("shmfile", 65); // 生成IPC键值
int semid = semget(key, 1, 0666|IPC_CREAT); // 创建信号量集合,只有一个信号量
int shmid = shmget(key, 1024, 0666|IPC_CREAT); // 创建共享内存
union semun sem_union;
sem_union.val = 1; // 信号量初值为1
struct sembuf ps = {0, -1, 0}; // 信号量-1操作
struct sembuf vs = {0, 1, 0}; // 信号量+1操作
// 初始化信号量
semctl(semid, 0, SETVAL, sem_union);
// 进程间通信的逻辑
// ...
// 清理IPC资源
shmctl(shmid, IPC_RMID, NULL);
semctl(semid, 0, IPC_RMID, sem_union);
return 0;
}
这个代码实例提供了一个简单的模板,展示了如何在Linux环境中使用共享内存和信号量来进行进程间同步和通信。这里使用了ftok
来生成键值,semget
来创建或获取信号量集合,semctl
来初始化信号量,shmget
来创建共享内存,并使用shmat
来附加共享内存到进程的地址空间。同步和通信的逻辑需要根据具体应用场景来实现。最后,代码展示了如何使用shmctl
和semctl
来删除或移除共享内存和信号量集合。
评论已关闭