• 信号量和互斥锁的区别 互斥量与临界区的区别


    互斥量与信号量的区别

    1. 互斥量用于线程的互斥,信号量用于线程的同步。
      这是互斥量和信号量的根本区别,也就是互斥和同步之间的区别。
      互斥:是指某一资源同时只允许一个访问者对其进行访问,具有唯一性和排它性。但互斥无法限制访问者对资源的访问顺序,即访问是无序的。
      同步:是指在互斥的基础上(大多数情况),通过其它机制实现访问者对资源的有序访问。在大多数情况下,同步已经实现了互斥,特别是所有写入资源的情况必定是互斥的。少数情况是指可以允许多个访问者同时访问资源
    2. 互斥量值只能为0/1,信号量值可以为非负整数。
      也就是说,一个互斥量只能用于一个资源的互斥访问,它不能实现多个资源的多线程互斥问题。信号量可以实现多个同类资源的多线程互斥和同步。当信号量为单值信号量是,也可以完成一个资源的互斥访问。
    3. 互斥量的加锁和解锁必须由同一线程分别对应使用,信号量可以由一个线程释放,另一个线程得到。

    临界区与互斥量的区别

    1.方式有点不一样,自己体会:临界区是对同一个资源进行加锁,然后可以对资源进行访问,其他要求访问该资源的线程被挂起,等待正在占用资源的线程释放锁,之后这些挂起的线程再次对资源进行竞争;而互斥量是创建了一个互斥量,拿到该互斥量的线程可以对资源进行访问,所谓拿到即对这个互斥量初值看作1,然后进行+/-操作,拿到的线程对其进行-1操作使其=0,其他线程看到为0自然知道资源被别人拿了
    2.使用范围:临界区只能同步本进程中的线程,而互斥量可以同步不同进程中的线程,因此,临界区很快,消耗资源少,而互斥量需要更多的资源

    信号是进程间通信的异步通信手段
    事件实现了线程之间的同步

  • 相关阅读:
    18寒假第一测
    P1932 A+B A-B A*B A/B A%B Problem
    POJ 2823 Sliding Window
    堆排序
    [LeetCode] Candy
    [LeetCode] Single Number II
    [LeetCode] Single Number
    [LeetCode] Binary Tree Postorder Traversal
    [LeetCode] Binary Tree Preorder Traversal
    [LeetCode] Insertion Sort List
  • 原文地址:https://www.cnblogs.com/sunshine-free/p/13733899.html
Copyright © 2020-2023  润新知