互斥和同步

互斥:是指散布在不同进程之间的若干程序片段,当某个进程执行其中的一个程序片段时,其他进程就不能运行它们之中的任一程序片段,只能等到该进程运行完之后才可以继续运行。

同步:是指散布在不同进程之间的若干程序片段,它们的运行必须严格按照一定的先后次序来运行,这种次序依赖于要完成的任务。比如数据的收发,必须发送方发送了接收方才能收。

        同步是一种更为复杂的互斥吗,而互斥是一种特殊的同步。互斥是两个进程或线程之间不可以同时运行,它们会互相排斥,必须等待其中的一个运行完,另一个才可以运行。而同步也是不可以同时运行,并且还需要按照某种顺序来运行。

总结:

  1. 互斥是指某一资源同时只允许一个访问者对其进行访问,具有唯一性和排它性。但互斥无法控制对资源的访问顺序
  2. 同步是指在互斥的基础上实现对资源的有序访问

实现互斥的方法

  1. 加锁
  2. 信号量(P、V操作)
  3. 硬件支持:
    1. 中断禁用:单处理机中,在进程执行临界区代码时不可以被中断。
    2. 专用机器指令:保证动作的原子性

实现同步的方法

  1. 信号量(P、V操作)
  2. 消息传递:send()、recv()
  3. 条件变量
  • 21
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
互斥同步是计算机科学中常见的概念,用于控制多个线程或进程之间的访问和操作。信号量是实现互斥同步的一种机制。 互斥同步都使用信号量来实现。它们之间的区别在于信号量的操作方法。 互斥是指在同一时间只能有一个线程或进程访问共享资源。在信号量中,互斥可以通过二进制信号量实现,即只有两个状态:0和1。当一个线程或进程想要访问共享资源时,它会请求信号量,并将信号量减1。如果信号量的值为0,则表示共享资源正在被另一个线程或进程使用,当前线程或进程需要等待。当另一个线程或进程释放共享资源时,它会增加信号量的值,此时等待的线程或进程可以重新请求信号量,获取共享资源并开始访问。 同步是指多个线程或进程在执行的时候需要按照特定的顺序执行,以确保正确性和一致性。在信号量中,同步可以通过计数信号量实现,即信号量的值可以大于1。当一个线程或进程想要执行某个操作时,它会请求信号量,并将信号量减1。如果信号量的值为0,则表示另一个线程或进程正在执行某个操作,当前线程或进程需要等待。当另一个线程或进程完成操作并释放信号量时,它会增加信号量的值,此时等待的线程或进程可以重新请求信号量,并开始执行操作。 因此,互斥同步的区别在于信号量的值的范围。二进制信号量用于互斥,计数信号量用于同步

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值