私のアプリケーションは、すべての UI コントロールにバインドされる Bindinglist から継承するカスタム リストを使用します。リストは、INotifyPropertyChanged を実装する baseobjects のコレクションです。メモリ リークが疑われ、memprofiler を使用してアプリケーションのプロファイリングを行ったところ、すべてのリストが決して破棄されず、バインディング リストの propertyChanged イベント ハンドラにサブスクライブされているため、それらがくっついていることが確認されました。
ここに私のオブジェクトのサンプルがあります
public abstract class BaseObject:IDataErrorInfo,INotifyPropertyChanged,ICloneable
{
private Guid _Id = Guid.NewGuid();
public virtual Guid ID
{
get { return this._Id; }
set { this._Id = value; this.OnPropertyChange(new
PropertyChangedEventArgs(propertyName)); }
}
[field:NonSerialized]
public virtual event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChange(PropertyChangedEventArgs e)
{
if (this.PropertyChanged != null) this.PropertyChanged(this, e);
}
}
[Serializable]
public class BaseList<T> :BindingList<T>,ICloneable where T:BaseObject
{
public new void Add(T item)
{
<Custom code>
base.Add(item);
}
public new void Remove(T item)
{
<Custom Code>
base.Remove(item);
}
}
プロファイラーからの割り当てスタックは次のとおりです
[Skipped frame(s)]
mscorlib!System.MulticastDelegate.CombineImpl( Delegate )
mscorlib!System.Delegate.Combine( Delegate, Delegate )
<AppName>.Data!<AppName>.Data.BaseObject.add_PropertyChanged(
PropertyChangedEventHandler )
[Skipped frame(s)]
System!System.ComponentModel.BindingList<T>.InsertItem( int, T )
mscorlib!System.Collections.ObjectModel.Collection<T>.Add( T )
<AppName>.Data.BaseList<T>.Add( T ) BaseList.cs
<AppName>.UI.Forms.Form1.GetData() Form1
<AppName>.UI.Forms.Form1.Initialize() Form1
<AppName>.UI.Forms.Form1.RunAsyncComplete() Form1
誰かがリストを処分するのを手伝ってくれますか?
皆さんありがとう
ヘンク、あなたは正しかった。問題は、私が言及したコードではなく、フォームの破棄を妨げているデリゲートに絞り込みました。サイトにアップロードする問題を再現するサンプルに取り組んでいます。ありがとう