P-Linq可以在委托执行期间切换线程吗?

时间:2012-04-11 19:11:02

标签: c# multithreading plinq

在执行委托期间上下文切换是否可以切换执行线程?

我在LinqPad中尝试了几次这个片段,并没有点击new Exception()行,这似乎表明它会在原始帖子上继续,但也许我的小测试不足以测试这个,我只是不确定。

void Main()
{
    var list = Enumerable.Range(1,100000);
    list.AsParallel().ForAll( i=>
    {
        var threadId = System.Threading.Thread.CurrentThread.ManagedThreadId;
        System.Threading.Thread.Sleep(0); // allow a context switch
        work(i,threadId); 
    });
    "Complete".Dump();
}

void work(int num,int threadId)
{
    var currentId = System.Threading.Thread.CurrentThread.ManagedThreadId;
    if(threadId!=currentId)
    {
        throw new Exception();
    }
}

2 个答案:

答案 0 :(得分:3)

当一个任务被安排时,它将永远使用分配给它的第一个线程。那个线程可能会停止运行,让另一个线程(来自线程池或不是)做一些工作,整个过程可以暂停,让另一个进程做一些工作,但无论你总是会在线程中找到什么你开始了。

答案 1 :(得分:2)

否 - 相同的方法无法在一个线程中开始执行而在另一个线程中完成。试想一下 - 每个线程都有自己的堆栈,如果可能的话,每个上下文切换都会复制堆栈。

在您的示例中,上下文切换时间切片将被赋予另一个线程,但它将执行另一个代码。另一个代码可能在同一个方法中,但调用堆栈可能是其他代码,threadiId也是其他代码。

所以你永远不会看到你的例外。