Mit der folgenden Erweiterungsmethode:
public static class EnumerableExtensions
{
public static IEnumerable<Task<TimedResult<TReturn>>> TimedSelect<TSource, TReturn>(
this IEnumerable<TSource> source,
Func<TSource, Task<TReturn>> func)
{
if (source == null) throw new ArgumentNullException("source");
if (func == null) throw new ArgumentNullException("func");
return source.Select(x =>
{
Stopwatch stopwatch = new Stopwatch();
stopwatch.Start();
Task<TReturn> task = func(x);
Task<TimedResult<TReturn>> timedResultTask = task
.ContinueWith(y =>
{
stopwatch.Stop();
return new TimedResult<TReturn>(task, stopwatch.Elapsed);
});
return timedResultTask;
});
}
}
public class TimedResult<T>
{
internal TimedResult(Task<T> task, TimeSpan duration)
{
Task = task;
Duration = duration;
}
public readonly Task<T> Task;
public readonly TimeSpan Duration;
}
Und callsite
var tasks = statements.TimedSelect(statement => _session.ExecuteAsync(statement));
var result = Task.WhenAll(tasks).Result;
können Sie die Ergebnisse extrahieren, die Sie
// Whatever works (ugly, but just as an example)...
var min = result.Select(x => x.Duration).Min();
var max = result.Select(x => x.Duration).Max();
var avg = new TimeSpan((long)result.Select(x => x.Duration.Ticks).Average());
Hinweis benötigen, dass dieser Pool Wartezeit beinhaltet (Zeit, die darauf wartet, dass ein Task-Thread verfügbar wird), und ist daher möglicherweise nicht korrekt.
Eine nicht-generische Variante dieser Erweiterung ist eine Übung für den Leser.
Dies ist nicht die Aufgabe einer Aufgabe. Was verhindert, dass Sie eine Stoppuhr verwenden, wie in [Wie lange dauert mein Code zum Ausführen?] (Http://stackoverflow.com/questions/1285052/how-long-does-my-code-take-to-run)) – CodeCaster
Ich habe versucht, Stoppuhr zu verwenden, aber ich weiß nicht, wie ich jede Aufgabe messen kann. –
Sie möchten also jede Aufgabe, nicht alle Aufgaben messen? Dann müssen Sie in jeder Aufgabe eine Stoppuhr implementieren. – CodeCaster