MFC线程(四):线程同步信号量(semaphore)

2024-05-11 11:08

本文主要是介绍MFC线程(四):线程同步信号量(semaphore),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面讲的三种保持线程同步的方法是临界区,事件,互斥.它们都有点类似,就是确保一次只有一个线程访问资源,独占一个资源.

而信号量就与它们不同,它是可以让很多线程同时访问一个资源,但是限制一次同时访问的数量.这样的资源一般是只读,所以不会造成资源的混乱.最简单的例子就是数据库中表的读操作,可以多个线程同时去读.而写可不行(只能一次让一个去写).

在这Server的编程中蛮有用,限制同时访问server的客户端是多少个.

 

Win32 API中的semphore
 

HANDLE hSemaphore;

CString szInfo = _T("I am useful info");

 

void MainTest(){

hSemaphore = CreateSemaphore(NULL,2,2,NULL);  //只能同时两个线程并发访问

AfxBeginThread(FunOne,NULL);

AfxBeginThread(FunTwo,NULL);

//如果再多加一个线程有可能出错,也可能不.假如恰好三个线程同时访问就出错,如果前面的某个已经访问完了那不会出错

}

 

UINT FunOne(LPVOID pParam){

WaitForSingleObject(hSemaphore, INFINITE);

CString info = szInfo;

ReleaseSemaphore(hSemaphore, 1, NULL);

}

 

UINT FunTwo(LPVOID pParam){

WaitForSingleObject(hSemaphore, INFINITE);

CString info = szInfo;

ReleaseSemaphore(hSemaphore, 1, NULL);

}

 

MFC中的semphore类
 

CSemaphore g_cSHE(2,2);

CString szInfo = _T("I am useful info");

 

void MainTest(){

AfxBeginThread(FunOne,NULL);

AfxBeginThread(FunTwo,NULL);

//如果再多加一个线程有可能出错,也可能不.假如恰好三个线程同时访问就出错,如果前面的某个已经访问完了那不会出错

}

 

UINT FunOne(LPVOID pParam){

g_cSHE.Lock();

CString info = szInfo;

g_cSHE.Unlock();

}

UINT FunTwo(LPVOID pParam){

g_cSHE.Lock();

CString info = szInfo;

g_cSHE.Unlock();

}
--------------------- 
作者:聪明的笨蛋 
来源:CSDN 
原文:https://blog.csdn.net/weiwenhp/article/details/8651735 
版权声明:本文为博主原创文章,转载请附上博文链接!

这篇关于MFC线程(四):线程同步信号量(semaphore)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/979361

相关文章

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J

异步线程traceId如何实现传递

《异步线程traceId如何实现传递》文章介绍了如何在异步请求中传递traceId,通过重写ThreadPoolTaskExecutor的方法和实现TaskDecorator接口来增强线程池,确保异步... 目录前言重写ThreadPoolTaskExecutor中方法线程池增强总结前言在日常问题排查中,

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r