操作系统 5. 同步模型;死锁问题

本文探讨了四个操作系统中的经典同步模型——皮特森算法、生产者消费者问题、读者写者问题以及贤者吃饭问题,并介绍了死锁的概念。通过对信号量的巧妙运用,这些模型展示了如何避免竞态条件并实现预期效果。同时,文章也涉及了死锁的避免、预防、检测和根除策略。
摘要由CSDN通过智能技术生成

这篇文章会讨论下4个经典的同步模型; 然后会说下死锁的避免,预防,检测和根除。

(1)经典的同步模型

*在操作系统第9版这本书里面, 我找到了4个比较经典的模型。其实大多都是对信号量的灵活运用来叫Race Condition来达到预期效果的小练习。 不知道在以后会不会用得到,不过记录下总是好的。 主要还是这些东西都很有意思。

1. Peterson's Solution(皮特森算法)

Peterson‘s Solution这个算法是一个实现互斥锁的算法。在我个人看来,所有模型里面这个算法是最牛逼的。 因为他单纯的用软件编程就实现了进程同步而不需要使用任何原子性操作方程。 既然是纯编程就能实现的东西, 那肯定要先撸个测试例子看看效果啦。
首先,先搞一个原始方程。 在上一章节里面用了线程同步, 这次换个进程玩玩。

#include<stdio.h>

#include<sys/shm.h>

#include<unistd.h>

#include<stdlib.h>

typedefstruct shared_data{

       int counter;

}shared_data;

main()

{

       int shmid,status;

       struct shared_data *data_ptr;

       shmid = shmget(IPC_PRIVATE,sizeof(struct shared_data),0664 | IPC_CREAT);

       int pid = fork();

       if ( pid <0 ){

               perror("fork出现错误\n");

       }elseif(pid ==0 ){

               data_ptr = (struct shared_data*) shmat(shmid,0,0);

               for(int i =0; i <1000000; i++ )

                       data_ptr -> counter ++;

               exit(0);

       }else{

               data_ptr = (struct shared_data*) shmat(shmid,0,0);

               for(int i =0; i <1000000; i++ )

                       data_ptr -> counter ++;

               wait(&status);

               printf("The Final Counter is%d\n", data_ptr -> counter);

               if(!shmdt(data_ptr))

                       printf("分离进程间共享内存\n");

               if(!shmctl(shmid, IPC_RMID,0))

                       printf("删除共享内存\n");

       }

}

测试结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值