MFC线程(三):线程同步事件(event)与互斥(mutex)

前面讲了临界区可以用来达到线程同步.而事件(event)与互斥(mutex)也同样可以做到.

Win32 API中的线程事件

HANDLE hEvent = NULL;

void MainTestFun{

hEvent = CreateEvent(NULL,FALSE,FALSE,NULL);

SetEvent(hEvent);

char g_charArray[4];

CString szResult;

//下面三个线程中的任意一个访问g_charArray的时候其他线程都不能访问

AfxBeginThread(FunOne,NULL); //FunOne给数组赋值全为S

AfxBeginThread(FunTwo,NULL); //FunTwo也给数组赋值全为B

AfxBeginThread(GetResult,);  //返回BBBB

}

//其他两个函数FunOne或GetResult也同样添加两行这样的代码.这两函数的定义见上一篇http://blog.csdn.net/weiwenhp/article/details/8650896

UINT FunOne(LPVOID pParam){

WaitForSingleObject(hEvent, INFINITE);  //类似EnterCriticalSection,这里的INFINITE表示会一直等其他的线程执行完了再执行.如果写成1000则表示只等1秒钟.1秒内

//其他线程还没有释放资源则该线程自动中止.

for(int i =0; i < 4; i++){

g_charArray[i] = ‘S‘;

Sleep(1);

}

SetEvent(hEvent);  //类似LeaveCriticalSection

return 0;

}

MFC中的线程事件类

CEvent g_cEvent; //实例化一个事件类

void MainTestFun{

g_cEvent.SetEvent();

char g_charArray[4];

CString szResult;

//下面三个线程中的任意一个访问g_charArray的时候其他线程都不能访问

AfxBeginThread(FunOne,NULL); //FunOne给数组赋值全为S

AfxBeginThread(FunTwo,NULL); //FunTwo也给数组赋值全为B

AfxBeginThread(GetResult,); //返回BBBB

}

//其他两个函数FunOne或GetResult也同样添加两行这样的代码.这两函数的定义见上一篇http://blog.csdn.net/weiwenhp/article/details/8650896

UINT FunOne(LPVOID pParam){

WaitForSingleObject(g_cEvent, INFINITE); //类似EnterCriticalSection

//其他线程还没有释放资源则该线程自动中止.

for(int i =0; i < 4; i++){

g_charArray[i] = ‘S‘;

Sleep(1);

}

g_cEvent.SetEvent(); //类似LeaveCriticalSection

return 0;

}

Win32 API中的互斥(mutex)

HANDLE hMutex = NULL;

void MainTestFun{

hMutex= CreateMutex(NULL,FALSE,NULL);

char g_charArray[4];

CString szResult;

//下面三个线程中的任意一个访问g_charArray的时候其他线程都不能访问

AfxBeginThread(FunOne,NULL); //FunOne给数组赋值全为S

AfxBeginThread(FunTwo,NULL); //FunTwo也给数组赋值全为B

AfxBeginThread(GetResult,); //返回BBBB

}

//其他两个函数FunOne或GetResult也同样添加两行这样的代码.这两函数的定义见上一篇http://blog.csdn.net/weiwenhp/article/details/8650896

UINT FunOne(LPVOID pParam){

WaitForSingleObject(hMutex, INFINITE);//类似EnterCriticalSection,这里的INFINITE表示会一直等其他的线程执行完了再执行.如果写成1000则表示只等1秒钟.1秒内

//其他线程还没有释放资源则该线程自动中止.

for(int i =0; i < 4; i++){

g_charArray[i] = ‘S‘;

Sleep(1);

}

ReleaseMutex(hMutex );//类似LeaveCriticalSection

return 0;

}

MFC中的互斥类(CMutex)

 

CMutex g_cMutex;

void MainTestFun{

char g_charArray[4];

CString szResult;

//下面三个线程中的任意一个访问g_charArray的时候其他线程都不能访问

AfxBeginThread(FunOne,NULL); //FunOne给数组赋值全为S

AfxBeginThread(FunTwo,NULL); //FunTwo也给数组赋值全为B

AfxBeginThread(GetResult,); //返回BBBB

}

//其他两个函数FunOne或GetResult也同样添加两行这样的代码.这两函数的定义见上一篇http://blog.csdn.net/weiwenhp/article/details/8650896

UINT FunOne(LPVOID pParam){

g_cMutex.Lock();//类似EnterCriticalSection,这里的INFINITE表示会一直等其他的线程执行完了再执行.如果写成1000则表示只等1秒钟.1秒内

//其他线程还没有释放资源则该线程自动中止.

for(int i =0; i < 4; i++){

g_charArray[i] = ‘S‘;

Sleep(1);

}

g_cMutex.Unlock();//类似LeaveCriticalSection

return 0;

}

时间: 2024-10-09 07:55:40

MFC线程(三):线程同步事件(event)与互斥(mutex)的相关文章

转--- 秒杀多线程第六篇 经典线程同步 事件Event

阅读本篇之前推荐阅读以下姊妹篇: <秒杀多线程第四篇 一个经典的多线程同步问题> <秒杀多线程第五篇 经典线程同步关键段CS> 上一篇中使用关键段来解决经典的多线程同步互斥问题,由于关键段的“线程所有权”特性所以关键段只能用于线程的互斥而不能用于同步.本篇介绍用事件Event来尝试解决这个线程同步问题. 首先介绍下如何使用事件.事件Event实际上是个内核对象,它的使用非常方便.下面列出一些常用的函数. 第一个 CreateEvent 函数功能:创建事件 函数原型: HANDLEC

秒杀多线程第六篇 经典线程同步 事件Event

阅读本篇之前推荐阅读以下姊妹篇: <秒杀多线程第四篇 一个经典的多线程同步问题> <秒杀多线程第五篇 经典线程同步关键段CS> 上一篇中使用关键段来解决经典的多线程同步互斥问题,由于关键段的"线程所有权"特性所以关键段只能用于线程的互斥而不能用于同步.本篇介绍用事件Event来尝试解决这个线程同步问题. 首先介绍下如何使用事件.事件Event实际上是个内核对象,它的使用非常方便.下面列出一些常用的函数. 第一个 CreateEvent 函数功能:创建事件 函数原

线程三线程安全

线程三线程安全对于多线程的系统来说,如果不加以限制的话,会造成数据安全等问题,对于数据安全问题会有如下问题:1.读取脏数据 在读取数据的时候,数据被修改了,而程序读取的是修改过的或者没有修改过的,反正不是自己期望读取的数据的值.2.数据不一致 在使用多线程进行数据处理的时候,最终得出来的数据每一次执行都不一样.3.数据错乱 在数据的打印或者数组中,会造成数据的顺序错乱,对于关系可能会错乱.--对于数据的安全性,java提供了一些解决的方法:1.使用synchronized同步关键字2.使用vol

python线程的同步事件Event

Event对象: 用于线程间的通信,某个线程需要根据其他线程的状态来判断自己的下一步操作. Event内部定义了一个全局变量:_flag,默认为False. 当_flag = False时,会阻塞当前线程的执行:_flag = True时,当前线程会继续执行. Event内部还定义了如下方法来操纵标志位: set() ——将_flag(标志位)设置为True: clear()——将_flag设置为False: is_set()——返回当前_flag的状态.等同于isSet(). wait()——

python38 1.线程一堆队列 2.事件Event 3.协程 4.断点续传

复习 1.GIL锁 2.如何避免GIL锁给程序带来的效率影响 3.与自定义锁的区别 4. 线程池进程池 5 同步  异步 6.异步回调 1.GIL锁 ? 全局解释器锁,   用来锁住解释器的互斥锁 ? 为啥加: CPython 中内存管理是非线程安全的,  GIL是为了   保护解释器的数据不被并发修改 ? 加锁后的问题:导致多个线程无法并行执行, 降低了效率 ? 当然 是可以并发的 ? 2.如何避免GIL锁给程序带来的效率影响 ? 什么时候会影响效率 ?  如果是计算密集型任务,开多线程不能提

C# 多线程(lock,Monitor,Mutex,同步事件和等待句柄)

本文来自:http://www.cnblogs.com/SkySoot/archive/2012/04/02/2430295.html 本篇从 Monitor,Mutex,ManualResetEvent,AutoResetEvent,WaitHandler 的类关系图开始,希望通过本篇的介绍能对常见的线程同步方法有一个整体的认识,而对每种方式的使用细节,适用场合不会过多解释. 让我们来看看这几个类的关系图: 1. lock 关键字     lock 是 C# 关键词,它将语句块标记为临界区,确

线程queue、事件event及协程

线程queue.事件event及协程 线程queue 多线程抢占资源,让其保持串行的两种方式: ? 1.互斥锁 ? 2.队列 线程队列分为以下三种: 1.Queue(先进先出) import queue q = queue.Queue(3) q.put(1) q.put(2) q.put(3) # q.put(4,block=False) # 若不设置block参数,默认为True,大于队列长度进入阻塞状态,若设置block为False,大于对列长度直接报错 print(q.get()) pri

线程同步之EVENT

事件可传信给其他线程,表示某些条件现在已具备,比如有可用的消息. 事件可分为手动复位和自动复位,前者可传信给许多同时等待事件的线程而且可以被复位. 自动复位的事件传信给单个等待时间的线程,该事件会自动复位. Applications can use event objects in a number of situations to notify a waiting thread of the occurrence of an event. For example, overlapped I/O

C#多线程:深入了解线程同步lock,Monitor,Mutex,同步事件和等待句柄(中)

本篇继续介绍WaitHandler类及其子类 Mutex,ManualResetEvent,AutoResetEvent的用法..NET中线程同步的方式多的让人看了眼花缭乱,究竟该怎么去理解呢?其实,我们抛开.NET环境看线程同步,无非是执行两种操作:一是互斥/加锁,目的是保证临界区代码操作的"原子性":另一种是信号灯操作,目的是保证多个线程按照一定顺序执行,如生产者线程要先于消费者线程执行..NET中线程同步的类无非是对这两种方式的封装,目的归根结底都可以归结为实现互斥/ 加锁或者是