zoukankan      html  css  js  c++  java
  • 多线程到底如何执行

    由一个简单的例子来分析多线程的执行,先看看简单的例子,代码如下:

    class Program
        {
            static int count = 0;
    
            static void Main(string[] args)
            {
                for (int i = 0; i < 10; i++)
                {
                    Thread t = new Thread(Run);
                    t.Name = i.ToString();
                    t.Start();
                }
    
                Console.Read();
            }
    
            static void Run()
            {
                ++count;
                Console.WriteLine("当前线程:{0},Count值为:{1}", Thread.CurrentThread.Name, count);
            }

    程序在本机上的执行结果,如上图所示。

    下面来分析下执行结果:

    for循环依次开了十个线程,然后调用了线程的Start方法。Start方法在MSDN的摘要为:导致操作系统将当前实例的状态更改为 System.Threading.ThreadState.Running。要注意的是调用线程的Start方法,并不代表线程能马上启动起来(也许CPU正在忙其他的事情)。如何判断线程真的执行起来呢,只需要借助线程的IsAlive属性。
    接下来,只根据上面的执行结果,看程序到底是如何跑的。

    "线程0",启动,线程立刻进入执行状态,执行Run()方法,静态字段count加1,输出当前线程名称,以及Count值。
    "线程1",启动,线程立刻进入执行状态,执行Run()方法,静态字段count加1,执行输出,没有完成输出。
    "线程2",启动,线程立刻进入执行状态。执行Run()方法,静态字段count加1,立即输出当前线程名称,以及Count值。
    "线程1" 完成输出。
    "线程3",启动,线程立刻进入执行状态。执行Run()方法,静态字段count加1,立即输出当前线程名称,以及Count值。
    "线程4",启动,线程立刻进入执行状态。执行Run()方法,静态字段count加1,还未执行输出。
    "线程5",启动,线程立刻进入执行状态。执行Run()方法,静态字段count加1,还未执行输出。
    "线程4",完成执行输出。
    "线程5",完成执行输出。
    下面的结果就不分析了。

    如何保证静态字段Count加一后,完成输出,下一个线程才能调用Run方法,也就是说Run方法,在当前线程执行完后,下一个线程才能执行。在实际编程中,这是经常会遇到的。
    我知道的有两个方法(都是对临界资源进行加锁),第一个使用lock,第二个是借助于Monitor的Enter、Exit方法。两个方法都需要一个静态的Object对象,当做临界资源。代码如下:

     static object lockObj = new object();
     
       lock (lockObj)
                {
                    ++count;
                    Console.WriteLine("当前线程:{0},Count值为:{1}", Thread.CurrentThread.Name, count);
                }
    static void Run()
            {
                Monitor.Enter(lockObj);
                ++count;
                Console.WriteLine("当前线程:{0},Count值为:{1}", Thread.CurrentThread.Name, count);
                Monitor.Exit(lockObj);
            }
    
    

      

  • 相关阅读:
    转:高层游戏引擎——基于OGRE所实现的高层游戏引擎框架
    转: Orz是一个基于Ogre思想的游戏开发架构
    转:Ogre源代码浅析——脚本及其解析(一)
    IntelliJ IDEA添加过滤文件或目录
    为什么要使用ConcurrentHashMap
    volatile关键字解析
    Spring Boot MyBatis 通用Mapper 自动生成代码
    使用mysql乐观锁解决并发问题
    使用Redis分布式锁处理并发,解决超卖问题
    浅析 pagehelper 分页
  • 原文地址:https://www.cnblogs.com/supperwu/p/2521502.html
Copyright © 2011-2022 走看看