在我的应用程序中,我有一个后台线程执行计算并将生成的ILnumerics数组推送到视图。 当我使用Control.BeginInvoke触发视图更新功能时,我遇到了ILNumerics数组被解决的问题。
将ILArrays作为输入参数传递给BeginInvoke委托时,是否有任何特定的函数规则?
这是我的示例代码。
void IMainView.UpdateSpectrumData(ILInArray<float> wfmData)
{
if (InvokeRequired)
{
BeginInvoke(new MethodInvoker(() => AddWfmToView(wfmData)), new object[] { wfmData });
}
else
{
AddWfmToView(wfmData);
}
}
}
void AddWfmToView(ILInArray<float> wfmData)
{
using(ILScope.Enter(wfmData))
{
// update panel
}
}
答案 0 :(得分:3)
问题是编译器会在幕后为你创建一个匿名类。需要捕获lambda表达式中使用的变量。对于该类,编译器将不遵循ILNumerics函数规则。这就是你看到过早处置的原因。
您的问题的答案是:lambda表达式不支持ILArray。如果您了解与之相关的所有细微之处,请谨慎使用。
在您的情况下,您可以通过回到ILNumerics.ILArray class usage来解决问题。在容器类(form / control?)中声明一个属性,该属性包含要用于更新的数据。从更新例程中,您可以正常访问该属性。对于大多数常见方案,您不需要任何同步。 (但一如既往:思考并做出有意识的决定!)
// a local attribute will 'transport' the data
ILArray<float> m_data = ILMath.localMember<float>();
public void UpdateView(ILInArray<float> wfmData) {
using (ILScope.Enter(wfmData)) {
m_data.a = wfmData;
AddWfmToView();
}
}
// the actual update method will not expose ILArray parameters. Hence we can use it in a lambda expression.
void AddWfmToView() {
if (InvokeRequired) {
Invoke(new MethodInvoker(() => AddWfmToView()));
} else {
// access control here if necessary
panel.Scene.First<ILLinePlot>().Update(m_data);
panel.Configure();
panel.Refresh();
}
}