У меня есть класс, реализующий UserControl. В .NET 2005 метод Dispose автоматически создается в файле частичного класса MyClass.Designer.cs, который выглядит следующим образом:
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
Если я хочу добавить свою собственную функциональность Dispose, где бы я ее поместил? Поскольку этот файл сгенерирован, я не хочу добавлять сюда код и рискую, что он улетит.





Я считаю, что в этом случае генератор кода уважает ваш код. Помещение его в программный код должно быть безопасным.
В VS 2005 (и 2008) вы можете обновить метод Dispose, и он не будет удален при редактировании элемента управления из дизайнера.
Вы можете переместить его из файла .designer.cs в основной файл .cs, если хотите. Как уже было сказано, он не будет перезаписан.
В таком случае я перемещаю сгенерированный метод Dispose в основной файл и расширяю его. Visual Studio уважает это.
Другой подход - использовать частичный метод (C# 3.0).
Метод Dispose в файле Designer может быть расширен для включения вызова частичного метода, который может быть реализован в основном файле.
Поскольку файл MyClass.Designer.cs уже является частичным файлом, вы можете просто добавить необходимую логику в уже созданный метод Dispose. Visual Studio не перезапишет метод после его создания, поэтому вы можете безопасно его изменить.
Все классы Component реализуют событие Disposed. Вы можете добавить обработчик событий для этого события и навести порядок в нем.
Например, в вашем UserControl вы можете добавить следующий метод:
private void OnDispose(object sender, EventArgs e)
{
// do stuff on dispose
}
И в конструкторе (или в обработчике событий Load) добавьте следующую строку:
Disposed += OnDispose;
@ Якоб Селезнев: Не уверен, почему больше людей не проголосовали за это. Может, они этого не видели? Я считаю событие Disposed правильным способом добавления функциональности удаления в любой поддерживающий его класс.
+1 - Я согласен с supercat, что это лучше, чем текущий принятый ответ.
Я считаю, что события должны обрабатываться извне класса, а не изнутри. Я предполагаю, что кто угодно может перезаписать обработчик событий своим собственным и предотвратить освобождение ресурсов. Правильный способ справиться с внутренними проблемами элемента управления - это переопределить правильный виртуальный метод, предоставляемый базовым классом.
Если вам нужно выполнить логику для компонентов элемента управления, таких как BindingSource, использование события Disposed не поможет - к тому времени компоненты уже были удалены. Похоже, что получение контроля над методом Dispose - единственный способ полностью контролировать поток. В моем случае это было необходимо для вызова BindingSource.Clear (), чтобы заставить созданный внутри BindingList отсоединить обработчики событий PropertyChanged и предотвратить утечку памяти.
Поскольку информация, передаваемая параметром disposing в void Dispose(bool disposing), не может быть доступна через событие Disposed (или, по крайней мере, я не могу ее найти; документация для члена Control.Disposing не указывает, что он разделяет семантику параметра disposing). Таким образом, с помощью события Disposed можно безопасно удалить только неуправляемые ресурсы.
Вам просто нужно перегрузить метод public void Dispose () в классе компонентов, который наследует пользовательский элемент управления.
убедитесь, что вы передаете вызов базовому методу, а также выполняете свое удаление функционально, иначе вы нарушите функциональность, если не реализуете ее полностью.
Это отличная идея. Для каждого реализованного Microsoft подкласса System.Windows.Forms.Control, который требует большего контроля над Dispose(bool disposing), вы можете создать подкласс и переопределить Dispose там, добавив вызов некоторого виртуального метода DisposeCore, как описано в ответ на другой вопрос. Вы можете прочитать значение параметра disposingи, но не редактировать файлы дизайнера. Выиграть / выиграть.
есть событие Unloaded для UserControl, которое вы можете использовать для очистки,
Этот вопрос касается WinForms UserControl, у которого не есть событие Unloaded. Возможно, вы имеете в виду элемент управления WPF или Silverlight?
Я бы подумал, что самым чистым способом было бы подписать ваш элемент управления на собственное событие Disposed () и выполнить там свою очистку.
Да, его нет в разделе файла "сгенерированный код".