ManualResetEvent类的用法

ManualResetEvent类的用法ManualResetEvent类作用1.事件初始状态设为false,task线程在第一个WaitOne()处阻塞。2.manualResetEvent.Set()事件状态设为true,task线程在每一个WaitOne()处都不阻塞。3.manualResetEvent调用Set()再调用Reset(),task线程在第一个WaitOne()处阻塞。4.manualResetEvent.Set()事件状态设为true,task线程在第一个WaitOne()处阻塞然后被释放。5.三个线程异步执行,set()

大家好,又见面了,我是你们的朋友全栈君。


在这里插入图片描述

#作用

一个线程通知其他一个或多个线程正在发送的事件。

ManualResetEvent manualResetEvent = new ManualResetEvent(false);

参数表示调用WaitOne()方法的线程是继续执行(true)还是阻塞(false)。

WaitOne():调用WaitOne()方法的线程会阻塞,等待主控线程的manualResetEvent.Set()信号。

Set():将事件状态设为true,调用WaitOne()的线程继续执行。
Reset():将事件状态设为false,调用WaitOne()的线程阻塞。

Set() Reset():只针对WaitOne()方法,不影响WaitOne()方法之前的程序执行。若没有信号,调用WaitOne()方法的线程一直阻塞。

1.事件初始状态设为false,task线程在第一个WaitOne()处阻塞。

using System;
using System.Threading;
using System.Threading.Tasks;
namespace ManualResetEvent测试
{ 
   
    class Program
    { 
   
        static ManualResetEvent manualResetEvent = new ManualResetEvent(false);

        static void Main(string[] args)
        { 
   
            //Task线程和主线程同时执行
            Task task = Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(1);
            });
            Console.ReadLine();
        }

        static void GetDataFromServer(int serverNumber)
        { 
   
            Console.WriteLine("I get first data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("I get second data from server" + serverNumber);
            Thread.Sleep(TimeSpan.FromSeconds(2));
            Console.WriteLine("I get third data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("All the data collected from server" + serverNumber);
        }
    }
}

输出:
I get first data from server1

2.manualResetEvent.Set()事件状态设为true,task线程在每一个WaitOne()处都不阻塞。

namespace ManualResetEvent测试
{ 
   
    class Program
    { 
   
        static ManualResetEvent manualResetEvent = new ManualResetEvent(false);

        static void Main(string[] args)
        { 
   
            //两个Task线程和主线程同时执行
            Task task = Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(1);
            });
            
            //主线程执行,将信号set为true,调用WaitOne()的线程被释放
            manualResetEvent.Set();
 
            Console.ReadLine();

        }

        static void GetDataFromServer(int serverNumber)
        { 
   
            Console.WriteLine("I get first data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("I get second data from server" + serverNumber);
            Thread.Sleep(TimeSpan.FromSeconds(2));
            Console.WriteLine("I get third data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("All the data collected from server" + serverNumber);
        }
    }
}

输出:
I get first data from server1
I get second data from server1
I get third data from server1
All the data collected from server1

3.manualResetEvent调用Set()再调用Reset(),task线程在第一个WaitOne()处阻塞。

namespace ManualResetEvent测试
{ 
   
    class Program
    { 
   
        static ManualResetEvent manualResetEvent = new ManualResetEvent(false);

        static void Main(string[] args)
        { 
   
            //两个Task线程和主线程同时执行
            Task task = Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(1);
            });
            
            //主线程执行,调用WaitOne()的线程被释放再马上阻塞
            manualResetEvent.Set();
 			manualResetEvent.Reset();
            Console.ReadLine();

        }

        static void GetDataFromServer(int serverNumber)
        { 
   
            Console.WriteLine("I get first data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("I get second data from server" + serverNumber);
            Thread.Sleep(TimeSpan.FromSeconds(2));
            Console.WriteLine("I get third data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("All the data collected from server" + serverNumber);
        }
    }
}

输出:
I get first data from server1

4.manualResetEvent.Set()事件状态设为true,task线程在第一个WaitOne()处阻塞然后被释放。

namespace ManualResetEvent测试
{ 
   
    class Program
    { 
   
        static ManualResetEvent manualResetEvent = new ManualResetEvent(false);

        static void Main(string[] args)
        { 
   
            //Task线程和主线程同时执行
            Task task = Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(1);
            });

			setEvent.Set();
            manualResetEvent.Reset();

            Thread.Sleep(TimeSpan.FromSeconds(8));
            manualResetEvent.Set();

            Console.ReadLine();
        }

        static void GetDataFromServer(int serverNumber)
        { 
   
            Console.WriteLine("I get first data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("I get second data from server" + serverNumber);
            Thread.Sleep(TimeSpan.FromSeconds(2));
            Console.WriteLine("I get third data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("All the data collected from server" + serverNumber);
        }
    }
}

输出:
先输出 I get first data from server1
然后task被阻塞,8秒后task获得Set()信号,再输出 I get second data from server1
再间隔2秒输出,第二个WaitOne()不会被阻塞
I get third data from server1
All the data collected from server1

5.三个线程异步执行,set()释放所有线程

namespace ManualResetEvent测试
{ 
   
    class Program
    { 
   
        static ManualResetEvent manualResetEvent = new ManualResetEvent(false);

        static void Main(string[] args)
        { 
   
            //两个Task线程和主线程同时执行
            Task task = Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(1);
            });

            Task.Factory.StartNew(() =>
            { 
   
                GetDataFromServer(2);
            });

            manualResetEvent.Set();
            manualResetEvent.Reset();

            Thread.Sleep(TimeSpan.FromSeconds(8));
            manualResetEvent.Set();
            
            Console.ReadLine();

        }

        static void GetDataFromServer(int serverNumber)
        { 
   
            Console.WriteLine("I get first data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("I get second data from server" + serverNumber);
            Thread.Sleep(TimeSpan.FromSeconds(2));
            Console.WriteLine("I get third data from server" + serverNumber);
            manualResetEvent.WaitOne();
            Console.WriteLine("All the data collected from server" + serverNumber);
        }
    }
}

输出:
先输出
I get first data from server1
I get first data from server2
然后task被阻塞,8秒后task获得Set()信号,再输出
I get second data from server2
I get second data from server1
再间隔2秒输出,第二个WaitOne()不会被阻塞
I get third data from server2
All the data collected from server2
I get third data from server1
All the data collected from server1

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161173.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 求两个矢量的夹角(带正负)[通俗易懂]

    求两个矢量的夹角(带正负)[通俗易懂]文章目录1由点乘求夹角,再判断正负向量点乘求夹角:2由点乘和叉乘,使用atan2(y,x)求角度1由点乘求夹角,再判断正负向量点乘求夹角:ab=|a||b|cos<a,b>=a.xb.x+a.y*b.y  所以<a,b>=acos((ab)/(|a||b|));  结果为正值,需要判定正负,来确定角方向;由向量叉乘判断正负:  aXb=……

    2022年8月30日
    1
  • 常见的9种大数据分析方法

    常见的9种大数据分析方法数据分析是从数据中提取有价值信息的过程,过程中需要对数据进行各种处理和归类,只有掌握了正确的数据分类方法和数据处理模式,才能起到事半功倍的效果,以下是数据分析员必备的9种数据分析思维模式:1.分类分类是一种基本的数据分析方式,数据根据其特点,可将数据对象划分为不同的部分和类型,再进一步分析,能够进一步挖掘事物的本质。2.回归回归是一种运用广泛的统计分析方法,可以通过规定因变量和…

    2022年5月6日
    47
  • iOS友盟消息推送总是推送失败或者token无效[通俗易懂]

    iOS友盟消息推送总是推送失败或者token无效[通俗易懂]最近遇到的问题,仅仅贴出来我的解决办法问题(开发环境下)我的原因AppleDevCenter中的开发者provisioningfile无效了,重新生成了一个就OK。选择iOSAppDevelopment然后一步步生成一个,下载到本地,双击安装。然后,手动的在buildSetttings中,修改codesign(因为我的电脑中有三个AppStore账号的证书,所以手动靠谱些

    2025年11月4日
    4
  • A股管家股票自动交易软件系统,功能完善强大[通俗易懂]

    A股管家股票自动交易软件系统,功能完善强大[通俗易懂]                                    2013年的时候,有个广东的朋友说再用这款A股管家股票自动系统,我当时比较惊讶,以前想过要是有一款股票自动交易软件能偶尔代替我一下就好了,虽然是职业股民,但也经常遇到太忙的时候,实在没时间。然后就在朋友的推荐下,弄了一套试试,印象非常深刻,当天设了600…

    2022年6月22日
    134
  • linux amd显卡驱动画面撕裂,从此告别画面撕裂 AMD-FreeSync技术解析

    linux amd显卡驱动画面撕裂,从此告别画面撕裂 AMD-FreeSync技术解析说到”垂直同步”技术,相信很多玩家都知道是啥意思,它可以有效解决游戏中的画面撕裂问题,让画面更平滑。然而它也有一个致命伤:会限制显卡的性能输出,进而造成卡顿。至于具体缘由,还要从显示器的工作原理说起。●为什么会有撕裂?目前几乎所有显示器的画面都是一行一行扫描上去的,刷新率通常固定为60Hz,而显卡在渲染不同画面时的速度不一样,简单画面渲染的快,复杂画面则要慢一些,当显卡输出和显示器输出不同步,…

    2022年6月7日
    38
  • 【插件】推荐两个谷歌浏览器的插件[通俗易懂]

    昨天加班到很晚,遇到一个很奇怪的问题,今天才大概定位产生的原因! 很多时候问题很难复现,导致排查问题的效率就不是那么的高效!本来想着写一下这次排查问题的总结,还是后面有时间在写。今天分享两个谷歌浏览器(程序员必备浏览器)的插件,我一直在用,特别好用,所以推荐给你!CSDN中屏蔽百度广告 – Adblock Plus插件我自己有时候会在CSDN写一些技术总结等,每次访问都会百度广告,真是TM…

    2022年2月27日
    165

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号