• Linux- 命名信号量和无名信号量的区别


    命名信号量和无名信号量之间的区别主要在于它们的可见性、生命周期以及如何在进程或线程之间共享。根据这些特点,它们各自更适合不同的应用场景:

    1. 命名信号量

      • 可见性:命名信号量由一个与其关联的名称标识,通常在某种文件系统(如/dev/shm/)中实现。这使得它们可以跨多个不相关的进程共享。

      • 生命周期:命名信号量的生命周期超出了创建它的进程。即使创建它的进程终止,命名信号量也会继续存在,直到明确使用sem_unlink()删除它。

      • 用途:由于上述特性,命名信号量特别适合于进程间同步。多个独立的进程可以通过信号量的名称来打开、等待或发布同一个信号量。

    2. 无名信号量

      • 可见性:无名信号量存在于进程的地址空间中,它们不关联任何外部的名称。为了在多个线程或进程之间共享无名信号量,它们必须拥有共享的内存区域(例如,由mmap()创建的共享内存区域)。

      • 生命周期:无名信号量的生命周期与包含它的进程相同。当进程终止时,无名信号量就不存在了。

      • 用途:由于上述特性,无名信号量特别适合于线程间的同步。在一个进程内,所有线程共享相同的内存空间,所以它们可以直接访问和操作同一个无名信号量。

    总的来说,区分这两种信号量类型的主要原因是因为进程和线程之间有基本的差异。进程通常是独立的、隔离的执行实体,拥有自己的地址空间。线程,另一方面,是进程内的轻量级实体,共享相同的地址空间。因此,进程间同步需要一个跨进程的可见机制,而线程间同步则可以在单一地址空间内完成。

  • 相关阅读:
    JQuery系列之ajax事件
    vue中v-for循环数组使用方法中splice删除数组元素(每次都删掉点击的下面的一项)
    大数据之Spark(一)
    道路千万条,为什么这家创新存储公司会选这条?
    Instant-NGP论文笔记
    【生物技术】专业与JAVA开发10年之缘
    LVM逻辑卷管理的知识总结和操作说明
    使用Avalonia跨Linux平台
    Spark基础【运行架构、RDD】
    懒加载
  • 原文地址:https://blog.csdn.net/weixin_43844521/article/details/133873063