Время жизни объектов в коллекции в VB.Net - PullRequest
2 голосов
/ 16 ноября 2010

Я пытаюсь выяснить время жизни tmpTabPages в следующем фрагменте кода. Предположим, что в форме есть пустой TabControl с именем MyTabControl, что есть коллекция строк с именем NameCollection.

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
    For Each itm In NameCollection
        Dim tmpTabPage as New TabPage(itm.toString)

        'Add Controls to tmpTabPage

        MyTabControl.TabPages.Add(tmpTabPage)
    Next
End Sub

Поскольку область действия tmpTabPage - это блок For / Next, как правило, его время жизни будет до конца блока, верно? Но поскольку он добавляется в коллекцию, имеющую область действия вне блока, он получает то же время жизни, что и коллекция, или в этом случае MyTabControl? Наконец, если я вызову MyTabControl.TabPages.Clear, будут ли уничтожены tmpTabPages в коллекции или они просто будут сидеть, занимая память?

Ответы [ 4 ]

5 голосов
/ 16 ноября 2010

Большое значение для классов, производных от Control (включая TabPage), представляет метод Dispose ().Они защищены от автоматической сборки мусора, Winforms хранит внутреннюю таблицу, которая сопоставляет дескриптор элемента управления со ссылкой на элемент управления.Вот почему, скажем, ваша основная форма не может внезапно получить мусор, даже если ваша программа не хранит ссылку на нее.

Добавление TabPage в коллекцию TabControl обеспечивает автоматическое удаление.То же самое относится и к TabControl, он будет добавлен в коллекцию Controls формы.Обычная цепочка событий заключается в том, что ваша программа или пользователь закрывают форму.Класс Form выполняет итерации своих дочерних элементов управления и вызывает их метод Dispose ().TabControl делает то же самое в своем методе Dispose (), удаляя вкладки.Окно Windows разрушается в процессе, удаляя дескриптор из этой таблицы сопоставления и теперь позволяя сборщику мусора, в конечном итоге, собирать управляемую оболочку для элементов управления.

Существует неприятная ловушка, которая попадает в число программистов Winformsв беде.Если вы удаляете элемент управления из коллекции его родителей, то вы сами несете ответственность за его удаление.Удаление не автоматически удаляет его.Winforms поддерживает родное окно, временно переопределяя элемент управления в скрытое окно, называемое «окном парковки».Хорошая функция, она позволяет вам перемещать элемент управления от одного родителя к другому без необходимости уничтожать и заново создавать элемент управления.

Но ключевое слово там «временно».Это только временно, если вы в следующий раз переучите контроль.Таким образом это перемещено от окна парковки до нового родителя.Если вы на самом деле не перекрасите его, то на окне парковки он останется живым навсегда.Сожрать ресурсы, пока программа не завершится.Это иначе известно как утечка.Он может привести к сбою вашей программы, если Windows отказывается создавать другое окно, когда вы уже создали 10 000 из них.

Метод ControlCollection.Clear () особенно вреден в этом случае. не располагает элементы управления, все они перемещаются в это парковочное окно.Если это не так, это редко случается, вам придется вызывать Dispose () для них самостоятельно.

3 голосов
/ 16 ноября 2010

Объекты в .NET получают право на сборку мусора, когда нет возможности добраться до них.В этом случае будет способом доступа к TabPage через коллекцию TabPages, пока либо он не будет удален из коллекции, либо сам элемент управления Tab не станет пригодным для коллекции.

Теперь, когда объект становится пригодным для сбора мусора, это не означает, что он собирается сразу же - сборка мусора выполняется в разное время в соответствии с довольно сложной эвристикой, а также существуют «поколения» памяти, которые усложняют работу.предсказывать.

Но в основном:

  • Вам не нужно беспокоиться о том, что объект, добавленный в коллекцию, будет таинственным образом собран и вызовет проблемы
  • Как правило, вам не нужно беспокоиться о том, что объекты будут пропускать память навсегда.Конечно, бывают ситуации, когда вам do необходимо предпринять некоторые активные шаги, чтобы убедиться, что объект пригоден для сбора, когда вы его больше не используете, но они относительно редко,(Обычно, по моему опыту, они связаны со статическими переменными и / или событиями.)
0 голосов
/ 16 ноября 2010

Вы добавляете в коллекцию только ссылку на объект TabPage, а не на объект TmpTabPage. Объект tmpTabPage в этом случае вы используете его только для выделения памяти.

0 голосов
/ 16 ноября 2010

, потому что у soemthing есть ссылки на элементы управления, от которых они не будут избавляться.

да, время жизни будет до конца процедуры, если вы не добавите ссылку на них в коллекцию.

очистка удалит объекты из коллекции и соберет мусор, если на них нет других ссылок (что не должно быть в описанной вами ситуации)

...