Читаем C# 4.0 полное руководство - 2011 полностью

Возвратить по очереди буквы от F до L:

F G Н I J К L

Создание обобщенного итератора

В приведенных выше примерах применялись необобщенные итераторы, но, конечно, ничто не мешает создать обобщенные итераторы. Для этого достаточно возвратить объект обобщенного типаIEnumeratorилиIEnumerable.Ниже приведен пример создания обобщенного итератора.

// Простой пример обобщенного итератора, using System;

using System.Collections.Generic;

class MyClass {

T [ ] array;

public MyClass(T[] a) { array = a;

}

// Этот итератор возвращает символы из массива chrs. public IEnumetator GetEnumerator    {

foreach(T obj in array) yield return obj;

}

}

class GenericItrDemo { static void Main {

int [ ] nums ={4, 3, 6,4,7, 9 };

MyClass me = new MyClass(nums);

foreach(int x in me)

Console.Write(x + " ");

Console.WriteLine;

bool[] bVals = { true, true, false, true };

MyClass mc2 = new MyClass(bVals);

foreach(bool b in mc2)

Console.Write(b + " ");

Console.WriteLine ;

}

}

Вот к какому результату приводит выполнение этой программы.

4 3 6 4 7 9

True True False True

В данном примере массив, состоящий из возвращаемых по очереди объектов, передается конструктору классаMyClass.Тип этого массива указывает в качестве аргумента типа в конструкторе классаMyClass.

МетодGetEnumerator оперирует данными обобщенного типаТи возвращает перечислитель типаIEnumerator.Следовательно, итератор, определенный в классеMyClass,способен перечислять данные любого типа.

Инициализаторы коллекций

В С# имеется специальное средство, называемоеинициализатором коллекциии упрощающее инициализацию некоторых коллекций. Вместо того чтобы явно вызывать методAdd , при создании коллекции можно указать список инициализаторов. После этого компилятор организует автоматические вызовы методаAdd , используя значения из этого списка. Синтаксис в данном случае ничем не отличается от инициализации массива. Обратимся к следующему примеру, в котором создается коллекция типаList,инициализируемая символами С, А, Е, В, D и F.

List 1st = new List { 'С1,    'А1,    'Е1,    'В1,    1D1,    1F1 };

После выполнения этого оператора значение свойства1st. Countбудет равно 6, поскольку именно таково число инициализаторов. А после выполнения следующего цикла foreach:

foreach(ch in 1st)

Console.Write(ch + " ");

получится такой результат:

С A E В D F

Для инициализации коллекции типаLinkedListcTKey, TValue>,в которой хранятся пары "ключ-значение", инициализаторы приходится предоставлять парами, как показано ниже.

SortedListcint, string> 1st =

new SortedListcint, string> { {1, "один11}, {2, "два" },    {3,    "три"}    };

Перейти на страницу:

Похожие книги

Access 2002: Самоучитель
Access 2002: Самоучитель

В книге рассматривается широкий круг вопросов, связанных с использованием программной среды Access 2002, которая является составной частью пакета Office 2002 и предназначена для создания банка данных в самых различных предметных областях.Подробно описывается методика проектирования объектов базы данных (таблицы, формы, отчеты, страницы доступа к данным, запросы, модули).Детально обсуждаются вопросы создания интегрированной базы данных в единой среде Access 2002: формирование БД с нуля, конвертирование в программную среду баз данных, созданных в ином программном окружении – Clarion, FoxPro.Особое внимание уделяется формированию разнообразных запросов к интегрированной базе данных Access 2002 с использованием языков программирования SQL, VBA и макросов.Приводятся общие сведения о возможностях языка обмена данными между различными компьютерами и приложениями (XML). Описываются возможности использования гиперссылок, связывающих базу данных с другими программными продуктами. Объясняется, как можно работать с базой данных Access 2002 без установки ее на компьютер, используя технологию ODBC (Open Data Base Connectivity). В приложениях приводятся количественные параметры Access 2002 и связанная с этой СУБД терминология.Предлагаемая книга будет полезна специалистам, занимающимся практической разработкой банков данных и приложений на их основе, а также студентам вузов, изучающим информатику.

Павел Юрьевич Дубнов

Программирование, программы, базы данных / ОС и Сети / Книги по IT