用于同步进程的信号量代码示例

本文介绍了如何使用Linux SystemV IPC信号量进行父子进程间的同步。通过示例代码展示了如何创建、操作和删除信号量,以及如何使用semget、semop和semctl系统调用。示例中,父进程和子进程共享一个信号量,通过调整信号量值实现同步。

注:本文章代码示例以及知识点来自《Linux高性能服务器编程》一书,对应章节13.5——信号量。

一、父、子进程间使用一个IPC_PRIVATE信号量来同步

Linux信号量的API有两组,一组是本文章中所使用的System V IPC信号量,其定义在sys/sem.h头文件中,主要包含3个系统调用:semget、semop、semctl,它们都被设计为操作一组信号量,即信号量集,而不是单个信号。;
另一组是与线程相关的POSIX信号量,其定义在头文件semaphore.h头文件中,具体参考章节14.4——POSIX信号量。

可以结合对比线程同步中的互斥锁来进行学习。

#include <sys/sem.h>
#include <cstdio>
#include <cstdlib>
#include <unistd.h>
#include <sys/wait.h>

union semun
{
    int val;
    struct semid_ds *buf;
    unsigned short int *array;
    struct seminfo *_buf;
};

void pv(int sem_id, int op) 
{
    struct sembuf sem_b;
    sem_b.sem_num = 0;
    sem_b.sem_op = op; 
    sem_b.sem_flg = SEM_UNDO;
    semop(sem_id, &sem_b, 1); 
}

int main(int argc, char *argv[])
{
    int sem_id = semget(IPC_PRIVATE, 1, 0666);

    union semun sem_un;
    sem_un.val = 1;
    semctl(sem_id, 0, SETVAL, sem_un);

    pid_t id = fork();
    if (id < 0)
    {   
        return 1;
    }
    else if (id == 0)
    {
        printf("child try to get binary sem\n");
        pv(sem_id, -1);
        printf("child get the sem and would release it after 5 seconds\n");
        sleep(5);
        pv(sem_id, 1);
        exit(0);
    }
    else
    {
        printf("parent try to get binary sem\n");
        pv(sem_id, -1);
        printf("parent get the sem and would release it after 5 seconds\n");
        sleep(5);
        pv(sem_id, 1);
    }

    waitpid(id, NULL, 0);
    semctl(sem_id, 0, IPC_RMID, sem_un);
    return 0;
}

二、运行结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值