我想将带有泛型参数的func传递给BackgroundWorker,但我偶然发现了如何在另一端投射和运行func。
以下代码演示了我正在尝试做的事情。请注意,我在所有Execute
方法中都有两个约束,BackgroundExecutionContext
和BackgroundExecutionResult
,我需要能够使用更多的通用参数。
public static class BackgroundExecutionProvider
{
public static void Execute<TValue, TResult>(Func<TValue, TResult> fc)
where TValue: BackgroundExecutionContext
where TResult: BackgroundExecutionResult
{
var bw = new BackgroundWorker();
bw.DoWork += new DoWorkEventHandler(Worker_DoWork);
bw.RunWorkerAsync(fc);
}
public static void Execute<TValue, T1, TResult>(Func<TValue, T1, TResult> fc)
where TValue : BackgroundExecutionContext
where TResult : BackgroundExecutionResult
{
var bw = new BackgroundWorker();
bw.DoWork += new DoWorkEventHandler(Worker_DoWork);
bw.RunWorkerAsync(fc);
}
public static void Execute<TValue, T1, T2, TResult>(Func<TValue, T1, T2, TResult> fc)
where TValue : BackgroundExecutionContext
where TResult : BackgroundExecutionResult
{
var bw = new BackgroundWorker();
bw.DoWork += new DoWorkEventHandler(Worker_DoWork);
bw.RunWorkerAsync(fc);
}
private static void Worker_DoWork(object sender, DoWorkEventArgs e)
{
// How do I cast the EventArgs and run the method in here?
}
}
您能否建议如何实现这一目标或采用不同的方法?
答案 0 :(得分:2)
使用闭包而不是尝试将值作为参数传递更容易:
public static void Execute<TValue, TResult>(Func<TValue, TResult> fc)
where TValue : BackgroundExecutionContext
where TResult : BackgroundExecutionResult
{
var bw = new BackgroundWorker();
bw.DoWork += (_, args) =>
{
BackgroundExecutionContext context = GetContext(); //or however you want to get your context
var result = fc(context); //call the actual function
DoStuffWithResult(result); //replace with whatever you want to do with the result
};
bw.RunWorkerAsync();
}