##// END OF EJS Templates
Слияние с default
Слияние с default

File last commit:

r45:d10034588e38 interactive logger
r46:9ce97b262a7a merge interactive logger
Show More
AsyncPool.cs
50 lines | 1.4 KiB | text/x-csharp | CSharpLexer
cin
initial log capabilities
r35 using Implab.Diagnostics;
cin
refactoring
r25 using System;
using System.Threading;
namespace Implab.Parallels {
/// <summary>
/// Класс для распаралеливания задач.
/// </summary>
/// <remarks>
/// Используя данный класс и лямда выражения можно распараллелить
/// вычисления, для этого используется концепция обещаний.
/// </remarks>
public static class AsyncPool {
cin
initial work on interactive logger
r45 public static IPromise<T> Invoke<T>(Func<T> func) {
cin
refactoring
r25 var p = new Promise<T>();
cin
improved tracing...
r40 var caller = TraceContext.Snapshot();
cin
refactoring
r25
ThreadPool.QueueUserWorkItem(param => {
cin
improved tracing...
r40 TraceContext.Transfer(caller);
cin
refactoring
r25 try {
cin
Implemented interllocked queue...
r14 p.Resolve(func());
cin
refactoring
r25 } catch(Exception e) {
p.Reject(e);
}
});
return p;
cin
Implemented interllocked queue...
r14 }
cin
initial work on interactive logger
r45 public static IPromise<T> InvokeNewThread<T>(Func<T> func) {
cin
Implemented interllocked queue...
r14 var p = new Promise<T>();
cin
improved tracing...
r40 var caller = TraceContext.Snapshot();
cin
initial log capabilities
r35
cin
Implemented interllocked queue...
r14 var worker = new Thread(() => {
cin
improved tracing...
r40 TraceContext.Transfer(caller);
cin
Implemented interllocked queue...
r14 try {
p.Resolve(func());
} catch (Exception e) {
p.Reject(e);
}
});
worker.IsBackground = true;
worker.Start();
return p;
cin
refactoring
r25 }
}
}