`
pcajax
  • 浏览: 2161582 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

semaphore

阅读更多
信号量  信号量(Semaphore),有时被称为信号灯,是在多线程环境下使用的一种设施, 它负责协调各个线程, 以保证它们能够正确、合理的使用公共资源。

信号量的概念

  Semaphore分为单值和多值两种,前者只能被一个线程获得,后者可以被若干个线程获得。
  以一个停车场是运作为例。为了简单起见,假设停车场只有三个车位,一开始三个车位都是空的。这时如果同时来了五辆车,看门人允许其中三辆不受阻碍的进入,然后放下车拦,剩下的车则必须在入口等待,此后来的车也都不得不在入口处等待。这时,有一辆车离开停车场,看门人得知后,打开车拦,放入一辆,如果又离开两辆,则又可以放入两辆,如此往复。
  在这个停车场系统中,车位是公共资源,每辆车好比一个线程,看门人起的就是信号量的作用。
  更进一步,信号量的特性如下:信号量是一个非负整数(车位数),所有通过它的线程(车辆)都会将该整数减一(通过它当然是为了使用资源),当该整数值为零时,所有试图通过它的线程都将处于等待状态。在信号量上我们定义两种操作: Wait(等待) 和 Release(释放)。 当一个线程调用Wait(等待)操作时,它要么通过然后将信号量减一,要么一直等下去,直到信号量大于一或超时。Release(释放)实际上是在信号量上执行加操作,对应于车辆离开停车场,该操作之所以叫做“释放”是因为加操作实际上是释放了由信号量守护的资源。

信号量的实现

  大家都知道,.Net Framework类库中提供的线程同步设施包括:
  Monitor, AutoResetEvent, ManualResetEvent,Mutex,ReadWriteLock和 InterLock。 其中 AutoResetEvent, ManualResetEvent,Mutex派生自WaitHandler,它们实际上是封装了操作系统提供的内核对象。而其它的应当是在.Net虚拟机中土生土长的。显然来自操作系统内核对象的设施使用起来效率要差一些。不过效率并不是我们这里要考虑的问题,我们将使用两个 Monitor 和 一个ManualResetEvent 对象来模拟一个信号量。
  代码如下:
  public class Semaphore
  {
  private ManualResetEvent waitEvent = new ManualResetEvent(false);
  private object syncObjWait = new object();
  private int maxCount = 1; file://最大资源数
  private int currentCount = 0; file://当前资源数
  public Semaphore()
  {
  }
  public Semaphore( int maxCount )
  {
  this.maxCount = maxCount;
  }
  public bool Wait()
  {
  lock( syncObjWait ) file://只能一个线程进入下面代码
  {
  bool waitResult = this.waitEvent.WaitOne(); file://在此等待资源数大于零
  if( waitResult )
  {
  lock( this )
  {
  if( currentCount > 0 )
  {
  currentCount--;
  if( currentCount == 0 )
  {
  this.waitEvent.Reset();
  }
  }
  else
  {
  System.Diagnostics.Debug.Assert( false, "Semaphore is not allow current count < 0" );
  }
  }
  }
  return waitResult;
  }
  }
  /**//// <summary>
  /// 允许超时返回的 Wait 操作
  /// </summary>
  /// <param name="millisecondsTimeout"></param>
  /// <returns></returns>
  public bool Wait( int millisecondsTimeout )
  {
  lock( syncObjWait ) // Monitor 确保该范围类代码在临界区内
  {
  bool waitResult = this.waitEvent.WaitOne(millisecondsTimeout,false);
  if( waitResult )
  {
  lock( this )
  {
  if( currentCount > 0 )
  {
  currentCount--;
  if( currentCount == 0 )
  {
  this.waitEvent.Reset();
  }
  }
  else
  {
  System.Diagnostics.Debug.Assert( false, "Semaphore is not allow current count < 0" );
  }
  }
  }
  return waitResult;
  }
  }
  public bool Release()
  {
  lock( this ) // Monitor 确保该范围类代码在临界区内
  {
  currentCount++;
  if( currentCount > this.maxCount )
  {
  currentCount = this.maxCount;
  return false;
  }
  this.waitEvent.Set(); file://允许调用Wait的线程进入
  }
  return true;
  }
  }
分享到:
评论

相关推荐

    semaphore完整搭建ansible部署方案

    Semaphore 是一个强大的自动化部署工具,它使用 Ansible 来实现对多主机的配置管理。Ansible 是一个流行的 IT 自动化框架,它允许管理员通过编写 YAML 格式的 Playbook 来执行任务,如软件部署、配置管理和应用生命...

    semaphore-develop.zip

    Semaphore是一款强大的持续集成/持续部署(CI/CD)工具,主要设计用于自动化软件构建、测试和部署流程。在这个"semaphore-develop.zip"压缩包中,包含的应该是Semaphore的开发源码,这对于理解其内部工作原理、自定义...

    使用信号量(Semaphore)实现线程的同步

    信号量(Semaphore)是操作系统中一种重要的同步机制,它用于管理多个线程对共享资源的访问,以防止并发执行时产生竞态条件。在多线程编程中,当多个线程试图同时访问一个有限的资源时,信号量可以帮助我们协调这些...

    Swift-dispatch-semaphore

    Swift中的`DispatchSemaphore`是GCD(Grand Central Dispatch)的一部分,它是Apple的多线程和并发解决方案。在iOS开发中,理解并熟练使用`DispatchSemaphore`对于优化代码性能和处理同步问题至关重要。本文将深入...

    semaphore控制多线程循序执行

    Semaphore(信号量)是一种经典的同步机制,它源自于荷兰计算机科学家Edsger W. Dijkstra提出的银行家算法。本示例中,我们将深入探讨如何使用Semaphore来控制多线程的循序执行。 Semaphore是一种计数信号量,它...

    C#语言Semaphore类用法实例(多线程多端口使用端口控制)

    在C#编程中,Semaphore类是线程同步和并发控制的重要工具,主要用于限制对特定资源的并发访问。在这个实例中,我们关注的是如何利用Semaphore来管理多线程对多个端口的访问,确保不会出现冲突。Semaphore类可以看作...

    pthread.h sched.h semaphore.h 三个头文件

    标题提到的"pthread.h"、"sched.h"和"semaphore.h"是三个在多线程编程和进程调度中常用的头文件,特别是在Linux和类Unix系统中。然而,这里我们看到这些文件在Windows环境下使用Cygwin进行darknet编译时也有所需求。...

    mutex和semaphore互斥程序实例

    `mutex`(互斥锁)和`semaphore`(信号量)都是用于实现线程同步和互斥的工具,确保同一时间只有一个线程可以访问特定的共享资源。本文将深入探讨这两种机制及其在实际编程中的应用。 一、互斥锁(Mutex) 互斥锁是...

    Semaphore进程间通讯测试源码

    Semaphore是Windows操作系统中的一种同步机制,它用于控制多个进程对共享资源的访问。在这个"Semaphore进程间通讯测试源码"中,我们可以看到如何在MFC(Microsoft Foundation Classes)框架下利用Semaphore实现进程...

    Linux下多线程编程-Pthread与Semaphore的使用.doc

    Linux 下多线程编程-Pthread 与 Semaphore 的使用 Linux 下的多线程编程是通过使用 POSIX 线程接口,称为 pthread 实现的。要编写 Linux 下的多线程程序,需要使用头文件 pthread.h,连接时需要使用库 libpthread.a...

    Ansible-semaphore.zip

    在 Ansible-semaphore.zip 文件中,包含的是 Semaphore 的源代码,特别是 "semaphore-master" 这个目录,这通常意味着它是项目的主分支或最新版本。 Semaphore 主要特点包括: 1. **Web GUI**:Semaphore 提供了一...

    利用semaphore实现shm进程通信

    ### 利用Semaphore实现SHM进程通信:深入解析与实践 #### 进程通信概述 在多进程系统中,进程间通信(IPC)是确保不同进程之间能够共享数据和协调运行的关键技术。根据《利用semaphore实现shm进程通信》一文,主要...

    Semaphore 源码解析

    Semaphore是Java并发编程中的一种重要工具,主要用于控制并发线程的访问权限,实现限流或资源的互斥访问。在高并发场景下,Semaphore能够有效地防止过多的线程同时访问共享资源,从而避免系统资源耗尽,提高系统性能...

    Semaphore的使用及其方法的使用

    Semaphore的使用及其方法的使用。

    Waitqueue、Event及Semaphore的实现机制分析

    在ARM架构中,Semaphore的实现位于`arch/arm/kernel/semaphore.c`和`include/asm-arm/semaphore.h`文件中。 总的来说,Waitqueue、Event和Semaphore都是Linux内核提供的重要同步和互斥机制,它们在多线程环境下保证...

    hardware_semaphore2.zip

    "hardware_semaphore2.zip"这个压缩包包含了一个硬件信号量的使用示例,对于初学者来说,理解这一概念是非常有益的。 硬件信号量是嵌入式系统中一种硬件支持的同步原语,与软件信号量相比,它的主要优势在于更高的...

    Semaphore_TBOX_产品-软件及系统功能

    根据提供的信息,我们可以深入探讨Semaphore_TBOX产品的软件及系统功能,特别是TBoxRTU的相关细节。这是一款专门针对工业自动化领域的远程终端单元(RTU),它不仅具备强大的数据采集能力,还集成了先进的软件工具,使...

    基于SPOC的ucosii_Semaphore实验

    在“基于SPOC的ucosii_Semaphore实验”中,我们将探讨如何利用SOPC(System on a Programmable Chip,可编程片上系统)技术和ucOS/II中的信号量机制来实现高效的资源管理。 SOPC技术是现代嵌入式系统设计的核心,它...

    Semaphore T-BOX System Overview.PDF

    Semaphore T-BOX System OverviewPDF,Semaphore T-BOX System Overview

Global site tag (gtag.js) - Google Analytics