この質問のフォローアップです。
https://stackoverflow.com/questions/12260170/how-to-make-a-threadpool-to-be-nonblocking
インターフェイスを使用してそれを達成しました。Action/deleages とインターフェイスを使用してノンブロッキングにしました。.net で以下のコードをノンブロッキングにする他の方法はありますか? インターフェースの実装は以下です。どの時点でも、Main、FuncA、FuncB の 3 つの関数のみを使用する必要があります。
誰かが親切に助けてくれたら。それは本当に感謝されます。ありがとうございました。
using System;
using System.Threading;
namespace ConsoleApplication2
{
public interface IOperation
{
void CallBack(int i);
}
public class FuncBCalculation
{
public int N { get { return _n; } }
private int _n;
public int MyValue { get; set; }
public FuncBCalculation(int n)
{
_n = n;
}
// Wrapper method for use with thread pool.
public void FuncB(object context)
{
IOperation FuncBcallback = (IOperation)context;
Thread.Sleep(5);
MyValue = _n + 2;
FuncBcallback.CallBack(MyValue);
}
}
public class ActualClass : IOperation
{
int Finalvalue = 0;
public static IOperation MainThreadCallBack { get; set; }
public void FuncA(int input, int i, IOperation callback)
{
input += 1;
var f = new FuncBCalculation(input);
MainThreadCallBack = callback;
IOperation op = new ActualClass();
ThreadPool.QueueUserWorkItem(f.FuncB, op);
}
//Method for callback operation
public void CallBack(int i)
{
Finalvalue = i + 3;
if (MainThreadCallBack != null)
MainThreadCallBack.CallBack(Finalvalue);
}
}
public class ThreadPoolExample : IOperation
{
static void Main()
{
ActualClass actualCall;
const int TotalLoopCount = 1000;
int input = 11;
Console.WriteLine("launching {0} tasks...", TotalLoopCount);
for (int i = 0; i < TotalLoopCount; i++)
{
IOperation op = new ThreadPoolExample();
actualCall = new ActualClass();
actualCall.FuncA(input, i, op);
}
Console.ReadKey();
}
//Method for callback operation for the main thread
public void CallBack(int i)
{
Console.WriteLine("The final Result is {0}", i);
}
}
}