linux进程间的通信--信号量同步

1.核心理论

  • 进程的同步:是指一组并发的进程互相合作互相等待,使得各进程按照一定的顺序执行的过程叫做进程同步。

  • 同步与互斥的区别:同步时信号量初始值为0,互斥时信号量初始值大于0。
    解释:如果用信号量互斥的话,必须是生产者进程先执行。如果采用信号量同步的话,那么那么生产者和消费者的执行顺序不影响结果

2.进程同步编程实例

  • 消费者与生产者的关系
    生产者进程:创建一个文件,向文件中写入字符,二者之间穿插一些休息
    消费者进程:该进程在生产者休息期间,读取文件内容,导致中间出现一些问题。
    简单来说就是必须要先生产完成,然后才能消费。

  • 生产者完成任务是才释放信号量。

  • producter.c

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>   
#include <fcntl.h>
#include <unistd.h>
#include <sys/ipc.h>
#include <sys/sem.h>

void main()
{
     int fd;
     key_t key;    
     int semid;
     struct sembuf sops;

     //创建一个键值
     key = ftok("home",1);

     //创建一个信号量
     semid = semget(key,1,IPC_CREAT);

     semctl(semid,0,SETVAL,0);

     fd = open("./pro.txt",O_RDWR|O_CREAT|O_APPEND,0777);

     sleep(15);

     write(fd,"welcome,linux!",14);

     //释放信号量
     sops.sem_num = 0;
     sops.sem_op = 1;
     sops.sem_flg = SEM_UNDO;
     semop(semid,&sops,1);

     close(fd);
}
  • consumer.c
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>

void main()
{
     key_t key;
     int semid;
     int ret;
     struct sembuf sops;

     key = ftok("home",1);//创建一个键值

     semid = semget(key,1,IPC_CREAT);//获取信号量
               //IPC_CREAT命令如果键值不存在就创建

     /*法一:通过轮寻查看信号量是否释放
     ret = semctl(semid,0,GETVAL);    
     printf("%d\n",ret);
     while(!(ret))
     ret = semctl(semid,0,GETVAL);     */

     //法二:采用信号量机制
     sops.sem_num = 0;//要操作的信号量序号
     sops.sem_op = -1;//设置为自减1
     sops.sem_flg = SEM_UNDO;//要操作的信号量序号
     semop(semid,&sops,1);//执行操作

     system("cp ./pro.txt ./temp");


}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值