Parallel.Invoke(Method1, Method2, /*...*/);
Task task1 = Task.Factory.StartNew(Method1);
Task task2 = TaskFactory.StartNew(Method2);
// ...
Task.WaitAll(task1, task2, /*...*/);
using(var cancellationTokenSource = new CancellationTokenSource())
{
var cancellationToken = cancellationTokenSource.Token;
var task = Task.Factory.StartNew(() =>
{
for(/*...*/)
{
cancellationToken.ThrowIfCancellationRequested();
// ...
}
}, cancellationToken);
cancellationTokenSource.Cancel();
}
try
{
var task = Task.Factory.StartNew( () => /*...*/ );
// ...
task.Wait(); // join
}
catch(AggregateException aggregateException)
{
aggregateException.Handle(exception =>
{
if(exception is /* ... */)
{
// handle exception
return true; // exception was handled
}
return false; // exception was not handled
});
}
public static void SpeculativeInvoke(params Action<CancellationToken>[] actions)
{
var cancellationTokenSource = new CancellationTokenSource();
var token = cancellationTokenSource.Token();
var tasks = actions.Select(action => Task.Factory.StartNew(() => action(token), token));
Task.WaitAny(tasks);
cancellationTokenSource.Cancel();
try
{
Task.WaitAll(tasks);
}
catch (AggregateException aggregateException)
{
// remove OperationCanceledException
aggregateException.Flatten().Handle(e => e is OperationCanceledException);
}
finally
{
if(cancellationTokenSource != null)
{
cancellationTokenSource.Dispose();
}
}
}
// current scheduler
TaskScheduler.Current
// default scheduler
TaskScheduler.Default
// scheduler for syncronizing with synchronization context of the current thread
// does not work with main thread
TaskScheduler.FromCurrentSyncronizationContext
Task<string> task;
using(var file = new StringReader("text"))
{
task = Task<string>.Factory.StartNew(() => file.ReadLine());
}
Console.WriteLine(task.Result);