线程同步--使用信号量

除了使用临界区与互斥可以完成线程间的同步外,还可以使用信号量CSemaphore。使用信号量还有一个好处便是:信号允许多个线程同时使用共享资源,这便与操作系统中的PV操作有些雷同的地方。它指出了同时访问共享资源的线程最大数目。

在信号量内部有一个计数器,当有线程访问共享资源时,计数器将自动递减,当它为0时,不再允许其他线程对共享资源的访问,直到有一个线程释放共享资源,从而完成对共享资源的保护。

在建立一个信号量时必须提供一个初始化值和一个最大计数值,如:

CSemaphore Semaphore(2,2);

可以在类的构造函数中动态地创建CSemaphore对象,如:

Semaphore=new CSemaphore(2,2);

信号量CSemaphore被建立后,就可以准备用它来对共享资源进行访问计数。要完成计数处理,首先应建立一个CSingleLock或CMultiLock对象,如:

CSingleLock SingleLock(Semaphore);

要减小这个信号Semaphore的计数值,只须调用CSingleLock对象的成员函数Lock()即可:

SingleLock.Lock();

同样,通过调用UnLock()来释放这个信号量,即:

SingleLock.UnLock();

从而我们可这样来申明类:

#include "afxmt.h"
class CSharedResource
{
private:
  CSemaphore* ptrSemaphore;
public:
  CSharedResource();
  ~CSharedResource();
 
  void AccessResource();
};

时间: 2025-01-27 00:41:00

线程同步--使用信号量的相关文章

4线程同步:信号量

1信号量 信号量可以有n把锁. 依赖的头文件 #include <semaphore.h> 函数声明 sem_t表示信号量   int sem_init(sem_t *sem, int pshared,unsigned int value); 名称: sem_init 功能: initialize an unnamed semaphore,初始化信号量sem_t,初始化的时候可以指定信号量的初始值,以及是否可以在多进程间共享. 头文件: #include <semaphore.h>

Windows 8 Store Apps学习(47) 多线程之线程同步: Semaphore等

多线程之线程同步: Semaphore, CountdownEvent, Barrier, ManualResetEvent, AutoResetEvent 介绍 重新想象 Windows 8 Store Apps 之 线程同步 Semaphore - 信号量 CountdownEvent - 通过信号数量实现线程同步 Barrier - 屏障 ManualResetEvent - 手动红绿灯 AutoResetEvent - 自动红绿灯 示例 1.演示 Semaphore 的使用 Thread

多线程-Delphi的线程同步的Mutex是引用计数的吗?引用计数的作用是什么?

问题描述 Delphi的线程同步的Mutex是引用计数的吗?引用计数的作用是什么? Delphi的线程同步的Mutex是引用计数的吗?引用计数的作用是什么? 解决方案 Mutex是互斥量,并且Mutex是可以跨进程的,所以开销比较大,它是操作系统封装的.它的用处,比如防止程序多开,进程同步等等. 线程同步用信号量临界区就可以了. 引用计数有不同的含义,通常我们说是指com对象的垃圾回收机制.com对象每创建一个引用指向它,引用计数+1,不再引用就-1,如果引用计数为0,代表com对象可以垃圾回收

重新想象 Windows 8 Store Apps (47) - 多线程之线程同步: Semaphore, CountdownEvent, Barrier, ManualResetEvent, AutoResetEvent

原文:重新想象 Windows 8 Store Apps (47) - 多线程之线程同步: Semaphore, CountdownEvent, Barrier, ManualResetEvent, AutoResetEvent [源码下载] 重新想象 Windows 8 Store Apps (47) - 多线程之线程同步: Semaphore, CountdownEvent, Barrier, ManualResetEvent, AutoResetEvent 作者:webabcd 介绍重新想

线程同步之Semaphore

线程同步之信号量 Semaphore 信号量. 它维护一个计数,当值大于0时,信号量对象处于已传信状态.通常用数值表示可用资源的个数. WaitForSingleObject()令信号量减一:ReleaseSemaphore()令信号量加一. 分析: 信号量值为6,MAX_SEM_COUNT ,而用到信号量的线程有8,THREADCOUNT,不包括main函数线程.所以前6个创建好的线程WaitForSingleObject()返回值为WAIT_OBJECT_0,不会阻塞.而接下来的线程Wait

vc++-信号量和线程同步的问题:线程函数比较耗时

问题描述 信号量和线程同步的问题:线程函数比较耗时 void trigger() { UINT uWait=::WaitForSingleObject(IEvent,INFINITE); if ( uWait == WAIT_OBJECT_0 ) { processA(); } } processA(); 比较耗时,如果它还没有跑完,下一个触发又来了,就马上又开始执行一个processA(); 吗,还是等待上次的执行完成然后再执行? 解决方案 PC机上会出现乱序或是假死,也就是说有可能后发的先做

线程同步傻问题:该被同步的变量没有用信号量控制,值是否会被改变

 线程同步傻问题:该被同步的变量没有用信号量控制,值是否会被改变 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading; 6 7 namespace testLockList 8 { 9 class Program 10 { 11 12 const int ThreadMaxNum = 5; //要启动的线程的最大

改善C#程序的建议6:在线程同步中使用信号量

原文:改善C#程序的建议6:在线程同步中使用信号量 所谓线程同步,就是多个线程之间在某个对象上执行等待(也可理解为锁定该对象),直到该对象被解除锁定.C#中对象的类型分为引用类型和值类型.CLR在这两种类型上的等待是不一样的.我们可以简单的理解为在CLR中,值类型是不能被锁定的,也即:不能在一个值类型对象上执行等待.而在引用类型上的等待机制,则分为两类:锁定和信号同步. 锁定,使用关键字lock和类型Monitor.两者没有实质区别,前者其实是后者的语法糖.这是最常用的同步技术: 本建议我们讨论

四种进程或线程同步互斥的控制方法

进程|控制 很想整理一下自己对进程线程同步互斥的理解.正巧周六一个刚刚回到学校的同学请客吃饭.在吃饭的过程中,有两个同学,为了一个问题争论的面红耳赤.一个认为.Net下的进程线程控制模型更加合理.一个认为Java下的线程池策略比.Net的好.大家的话题一下转到了进程线程同步互斥的控制问题上.回到家,想了想就写了这个东东.  现在流行的进程线程同步互斥的控制机制,其实是由最原始最基本的4种方法实现的.由这4种方法组合优化就有了.Net和Java下灵活多变的,编程简便的线程进程控制手段.  这4种方