Как и где использовать перечислители

Как использовать перечислители

Cells Счетчик

Существуют различные способы доступа к перечислителю Cells, и любой из этих способов можно использовать в зависимости от требований приложения. Вот методы, которые возвращают перечислитель ячеек.

  1. Cells.GetEnumerator
  2. Row.GetEnumerator
  3. Range.GetEnumerator

Все вышеперечисленные методы возвращают перечислитель, который позволяет обойти коллекцию ячеек, которые были инициализированы.

В следующем примере кода демонстрируется реализация интерфейса IEnumerator для коллекции Cells.

Перечислитель строк

Доступ к перечислителю строк можно получить при использованииRowCollection.GetEnumerator метод. В следующем примере кода демонстрируется реализация интерфейса IEnumerator дляRowCollection.

Перечислитель столбцов

Доступ к перечислителю столбцов можно получить при использованииColumnCollection.GetEnumerator метод. В следующем примере кода демонстрируется реализация интерфейса IEnumerator дляКолонкаКоллекция.

Где использовать перечислители

Чтобы обсудить преимущества использования счетчиков, давайте рассмотрим пример в реальном времени.

Сценарий

Требование к приложению состоит в том, чтобы обойти все ячейки в заданномРабочий листчитать их значения. Способов реализации этой цели может быть несколько. Некоторые из них показаны ниже.

Использование диапазона отображения

Использование MaxDataRow и MaxDataColumn

Как вы можете заметить, оба вышеупомянутых подхода используют более или менее схожую логику, то есть; цикл по всем ячейкам в коллекции, чтобы прочитать значения ячеек. Это может быть проблематично по ряду причин, как описано ниже.

  1. API, такие какМаксРоу, Максдатаров, Максколумн, Максдатаколумн & MaxDisplayRangeтребуется дополнительное время для сбора соответствующей статистики. Если матрица данных (строки x столбцы) велика, использование этих API может привести к снижению производительности.
  2. В большинстве случаев создаются не все ячейки в заданном диапазоне. В таких ситуациях проверять каждую ячейку матрицы не так эффективно, как проверять только инициализированные ячейки.
  3. Доступ к ячейке в цикле как строка Cells, столбец приведет к созданию экземпляров всех объектов ячеек в диапазоне, что в конечном итоге может вызвать исключение OutOfMemoryException.

Заключение

Основываясь на вышеупомянутых фактах, ниже приведены возможные сценарии использования счетчиков.

  1. Требуется доступ только для чтения к коллекции ячеек, т.е. требование состоит только в проверке ячеек.
  2. Необходимо пройти большое количество клеток.
  3. Только инициализированные ячейки/строки/столбцы должны быть пройдены.