使用本地var的线程时的奇怪行为

时间:2013-08-07 08:04:12

标签: c#

我写了一个简单的代码

void go()
{
    int i = 5;
    ThreadPool.QueueUserWorkItem(delegate
    {
        for (int j = 1; j <= 1000; j++)
            Console.Write(i);
    });
    for (int k = 1; k <= 1000; k++)
        i = k;
    Console.ReadLine();
}

我得到的是:100010001000100010001000....

我不知道为什么,我希望有人可以向我解释一下,谢谢!

2 个答案:

答案 0 :(得分:3)

在排队的线程启动之前运行将k分配给i的循环。

因此,在排队的线程启动时,i的值为1000,这就是您所看到的。

答案 1 :(得分:1)

将代码更改为

    void go()
    {
        int i = 5;
        int i1 = i; //note this
        ThreadPool.QueueUserWorkItem(delegate
        {
            for (int j = 1; j <= 1000; j++)
                Console.Write(i1); //and note this
        });
        for (int k = 1; k <= 1000; k++)
            i = k;
        Console.ReadLine();
    }

Resharper reports "Access to modified closure".