ゲッタースレッドを安全にしたいと思います。私はこれを行うと、私はエラーを取得する:C#InvokeRequired with property getter
Cannot cast expression of type 'Foo.Model.ApplicationViewModel' to type 'Action<ApplicationViewModel>'
ゲッタースレッドを安全にしたいと思います。私はこれを行うと、私はエラーを取得する:C#InvokeRequired with property getter
Cannot cast expression of type 'Foo.Model.ApplicationViewModel' to type 'Action<ApplicationViewModel>'
たくさん書くことができます:あなたはBeginInvokeメソッド、Invoke
はあなたがアクション<を使用することはできません
Func<>
が必要ですelse
が必要です。生成:
public ApplicationViewModel SelectedApplication
{
get
{
if (this.InvokeRequired)
return (ApplicationViewModel)this.Invoke(new Func<ApplicationViewModel>(() => this.SelectedApplication));
else
return _applicationsCombobox.SelectedItem as ApplicationViewModel;
}
}
を低レベルのプロパティ内のスレッドのコンテキストスイッチを非表示には、通常は間違いです。呼び出しには多くのオーバーヘッドがあり、結果のコードは非常に遅くなってしまい、なぜそれが遅いのかというヒントはありません。
試してみてください:
public ApplicationViewModel SelectedApplication
{
get
{
if (InvokeRequired)
{
BeginInvoke(() => { return SelectedApplication(); });
}
return _applicationsCombobox.SelectedItem as ApplicationViewModel;
}
}
ありがとうございますが、今度は「SelectedApplication();メソッドで「メソッド、イベント、またはデリゲートが必要です」と表示されます。 – Gui
BeginInvoke
と、デリゲートを取る
public ApplicationViewModel SelectedApplication
{
get
{
if (InvokeRequired)
{
BeginInvoke((Action<ApplicationViewModel>)SelectedApplication);
}
return _applicationsCombobox.SelectedItem as ApplicationViewModel;
}
}
私がエラーを持っています。
あなたは間違ったことの
return (ApplicationViewModel)Invoke(new Func<object>(() => applicationsCombobox.SelectedItem));
コンシューマには透過的ですが、このプロパティを同期的に取得するために、他のメソッドがどのように呼び出されたかを気にする必要はありません。呼び出し元がUIスレッド上にあることを100%確信した場合にのみ、速度の低下を減らすことができます。 – KeithS