using Implab.Diagnostics;
using System;
using System.Threading;
using System.Linq;
namespace Implab.Parallels {
///
/// Класс для распаралеливания задач.
///
///
/// Используя данный класс и лямда выражения можно распараллелить
/// вычисления, для этого используется концепция обещаний.
///
public static class AsyncPool {
public static IPromise Invoke(Func func) {
var p = new Promise();
var caller = TraceContext.Instance.CurrentOperation;
ThreadPool.QueueUserWorkItem(param => {
TraceContext.Instance.EnterLogicalOperation(caller,false);
try {
p.Resolve(func());
} catch(Exception e) {
p.Reject(e);
} finally {
TraceContext.Instance.Leave();
}
});
return p;
}
public static IPromise RunThread(Func func) {
var p = new Promise();
var caller = TraceContext.Instance.CurrentOperation;
var worker = new Thread(() => {
TraceContext.Instance.EnterLogicalOperation(caller,false);
try {
p.Resolve(func());
} catch (Exception e) {
p.Reject(e);
} finally {
TraceContext.Instance.Leave();
}
});
worker.IsBackground = true;
worker.Start();
return p;
}
public static IPromise RunThread(Action func) {
var p = new Promise();
var caller = TraceContext.Instance.CurrentOperation;
var worker = new Thread(() => {
TraceContext.Instance.EnterLogicalOperation(caller,false);
try {
func();
p.Resolve();
} catch (Exception e) {
p.Reject(e);
} finally {
TraceContext.Instance.Leave();
}
});
worker.IsBackground = true;
worker.Start();
return p;
}
public static IPromise[] RunThread(params Action[] func) {
return func.Select(f => RunThread(f)).ToArray();
}
public static IPromise[] RunThread(params Func[] func) {
return func.Select(f => RunThread(f)).ToArray();
}
}
}