• 【深度好文】多线程之WaitHandle-->派生EventWaitHandle事件构造-》AutoResetEvent、ManualResetEvent


    AutoResetEvent/ManualResetEvent 都是继承自 EventWaitHandle ,EventWaitHandle继承自WaitHandle.

    在讨论这个问题之前,我们先了解这样一种观点,线程之间的通信是通过发信号来进行沟通的。(这不是废话)

          先来讨论ManualResetEvent,讨论过程中我会穿插一些AutoResetEvent的内容,来做对比:

          ManualResetEvent都可以阻塞一个或多个线程,直到收到一个信号告诉ManualResetEvent不要再阻塞当前的线程。

    可以想象ManualResetEvent这个对象内部有一个Boolean类型的属性IsRelease来控制是否要阻塞当前线程。这个属性我们在初始化的时候可以设置它,如ManualResetEvent event=new ManualResetEvent(false);这就表明默认的属性是要阻塞当前线程。

          代码举例:

            ManualResetEvent _manualResetEvent = new ManualResetEvent(false);

            private void BT_Temp_Click(object sender, RoutedEventArgs e) 
            { 
                Thread t1 = new Thread(this.Thread1Foo); 
                t1.Start(); //启动线程1
                Thread t2 = new Thread(this.Thread2Foo); 
                t2.Start(); //启动线程2
                Thread.Sleep(3000); //睡眠当前主线程,即调用BT_Temp_Click的线程
                _manualResetEvent .Set();   //想象成将IsRelease设为True 
            }

            void Thread1Foo() 
            { 
                _manualResetEvent .WaitOne(); 

    //阻塞线程1,直到主线程发信号给线程1,告知_menuResetEvent你的IsRelease属性已经为true,

    //这时不再阻塞线程1,程序继续往下跑

                MessageBox.Show("t1 end"); 
            }

            void Thread2Foo() 
            { 
                _manualResetEvent .WaitOne();

    //阻塞线程2,直到主线程发信号给线程1,告知_menuResetEvent你的IsRelease属性已经为true,

    //这时不再阻塞线程2,程序继续往下跑

                MessageBox.Show("t2 end"); 
            }

           注意这里ManualResetEvent和AutoResetEvent的一个重要区别:

           1.manual的话肯定会给线程1和线程2都发送一个信号,而auto只会随机给其中一个发送信号,也就是只有一方可以继续行动。

           为什么一个叫manual而一个叫auto呢?我想这是很多人的疑问,现在我们就来看这个问题。

           2.刚才_manualResetEvent .Set();的这句话我想大家都明白了,可以看做将IsRelease的属性设置为true.线程1中

     _manualResetEvent.WaitOne();接收到信号后不再阻塞线程1。在此之后的整个过程中IsRelease的值都是true.如果

    想将IsRelease的值回复成false,就必须再调用_manualResetEvent.Reset()的方法。

      

  • 相关阅读:
    0713学期末了
    Oracle Redo日志的状态
    crontab调用shell访问sqlplus失败原因
    Solaris下批量杀进程
    oracle用户管理的完全恢复4:在ARCHIVELOG 模式(恢复打开的数据库)
    oracle用户管理的完全恢复3:在ARCHIVELOG 模式(恢复关闭的数据库)
    shell删除所有空行(忽略编码格式)
    oracle用户管理的完全恢复1:在NOARCHIVELOG 模式下执行恢复
    查看oracle用户权限
    OLTP与OLAP介绍
  • 原文地址:https://www.cnblogs.com/x-poior/p/6305652.html
Copyright © 2020-2023  润新知