4
var hs = new HashSet<int>();

foreach(var item in mainclass)
{
    Task<List<Class1>> cl1Task = Task.Factory.StartNew<List<Class1>>(() =>
    {
        if (!hs_VersiodIDs.Contains(item.VersionID))
        {
             return new List<Class1>(.....);
        }
        else
        {
            return null;
        }
    });

    Task.WaitAll(cl1Task );
}

它不等待任务完成。问题在于 return null 那么我怎样才能返回空任务?

4

1 回答 1

2

您的代码没有意义有两个原因:

  1. 启动一个不包含任何长时间运行代码的任务是没有用的。你不会从中获得任何好处
  2. 等待任务在启动后立即完成,完全否定了任务的效果:你仍然阻塞你的主线程。

如果任务中的代码真的那么简单,请将您的代码更改为:

foreach(var item in mainclass) 
{
    List<Class1> result;
    if (!hs_VersiodIDs.Contains(item.VersionID)) 
    { 
         result = new List<Class1>(.....); 
    } 
    else 
    { 
        result = null; 
    } 
} 

如果任务中的代码确实做了一些昂贵的事情,请将您的代码更改为:

var tasks = new List<Task>();
foreach(var item in mainclass)     
{     
    Task<List<Class1>> cl1Task = Task.Factory.StartNew<List<Class1>>(() =>     
    {     
        if (!hs_VersiodIDs.Contains(item.VersionID))     
        {     
             return new List<Class1>(.....);     
        }     
        else     
        {     
            return null;     
        }     
    });     

    tasks.Add(cl1Task); 
} 

// note, WaitAll is outside the loop, so now our tasks can all run in parallel
Task.WaitAll(tasks.ToArray());
于 2012-09-11T11:26:16.780 回答