Категории
Самые читаемые
PochitayKnigi » Разная литература » Прочее » C# 4.0 полное руководство - 2011 - Герберт Шилдт

C# 4.0 полное руководство - 2011 - Герберт Шилдт

Читать онлайн C# 4.0 полное руководство - 2011 - Герберт Шилдт

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 40 41 42 43 44 45 46 47 48 ... 268
Перейти на страницу:

// Продемонстрировать применение свойства Length // при обращении со ступенчатыми массивами.

using System;

class Jagged {

static void Main() {

int[][] network_nodes = new int[4][]; network_nodes[0] = new int[3]; network_nodes[1] = new int[7]; network_nodes[2] = new int[2]; network_nodes[3] = new int[5];

int i, j;

// Сфабриковать данные об использовании ЦП. for(i=0; i < network_nodes.Length; i++)

for(j=0; j < network_nodes[i].Length; j++) network_nodes[i][j] = i * j + 70;

Console.WriteLine("Общее количество узлов сети: " + network_nodes.Length + "n");

for(i=0; i < network_nodes.Length; i++)    {

for(j=0; j < network_nodes[i].Length; j++)    {

Console.Write("Использование в узле сети " + i +

" ЦП " + j + ": ");

Console.Write(network_nodes[i][j] + "% ");

Console.WriteLine ();

}

При выполнении этой программы получается следующий результат.

Общее количество узлов

сети:

: 4

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

в

узле

0

ЦП

0

70%

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

в

узле

0

ЦП

1

70%

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

в

узле

0

ЦП

2

70%

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

в

узле

1

ЦП

0

70%

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

в

узле

1

ЦП

1

71%

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

в

узле

1

ЦП

2

72%

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

в

узле

1

ЦП

3

73%

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

в

узле

1

ЦП

4

74%

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

в

узле

1

ЦП

5

75%

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

в

узле

1

ЦП

6

76%

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

в

узле

2

ЦП

0:

: 70%

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

в

узле

2

ЦП

1:

: 72%

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

в

узле

3

ЦП

0:

: 70%

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

в

узле

3

ЦП

1:

: 73%

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

в

узле

3

ЦП

2:

: 76%

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

в

узле

3

ЦП

3:

: 79%

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

в

узле

3

ЦП

4:

: 82%

Обратите особое внимание на то, как свойство Length используется в ступенчатом массиве network_nodes. Напомним, что двумерный ступенчатый массив представляет собой массив массивов. Следовательно, когда используется выражение

network_nodes.Length

то в нем определяется число массивов, хранящихся в массиве network_nodes (в данном случае — четыре массива). А для получения длины любого отдельного массива, составляющего ступенчатый массив, служит следующее выражение.

n.etwork_nodes [0] .Length

В данном случае это длина первого массива.

Неявно типизированные массивы

Как пояснялось в главе 3, в версии C# 3.0 появилась возможность объявлять неявно типизированные переменные с помощью ключевого слова var. Это переменные, тип которых определяется компилятором, исходя из типа инициализирующего выражения. Следовательно, все неявно типизированные переменные должны быть непременно инициализированы. Используя тот же самый механизм, можно создать и неявно типизированный массив. Как правило, неявно типизированные массивы предназначены для применения в определенного рода вызовах, включающих в себя элементы языка LINQ, о котором речь пойдет в главе 19. А в большинстве остальных случаев используется "обычное" объявление массивов. Неявно типизированйые массивы рассматриваются здесь лишь ради полноты представления о возможностях языка С#.

Неявно типизированный массив объявляется с помощью ключевого слова var, но без последующих квадратных скобок [ ]. Кроме того, неявно типизированный маесив должен быть непременно инициализирован, поскольку по типу инициализаторов определяется тип элементов данного массива. Все инициализаторы должны быть одного и того же согласованного типа. Ниже приведен пример объявления неявно типизированного массива.

var vals = new[]    { 1, 2, 3, 4, 5 };

В данном примере создается массив типа int, состоящий из пяти элементов. Ссылка на этот массив присваивается переменной vals. Следовательно, тип этой переменной соответствует типу int массива, состоящего из пяти элементов. Обратите внимание на то, что в левой части приведенного выше выражения отсутствуют квадратные скобки [ ]. А в правой части этого выражения, где происходит инициализация массива, квадратные скобки присутствуют. В данном контексте они обязательны.

Рассмотрим еще один пример, в котором создается двумерный массив типа double.

var vals = new[,] { {1.1, 2.2}, {3.3, 4.4}, { 5.5, 6.6} };

В данном случае получается массив vals размерами 2x3.

Объявлять можно также неявно типизированные ступенчатые массивы. В качестве примера рассмотрим следующую программу.

// Продемонстрировать неявно типизированный ступенчатый массив.

using System;

class Jagged {

static void Main() {

var jagged = new[]    {

new [ ] { 1, 2, 3, 4 }, new[] { 9, 8, 7 }, new[] { 11, 12, 13, 14, 15 }

};

for(int j =0; j < jagged.Length; j++)    {

for(int i-0; i < jagged[j].Length; i++)

Console.Write(jagged[j] [i] + " ") ;

Console.WriteLine();

}

}

}

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

12 3 4 9 8 7

11 12 13 14 15

Обратите особое внимание на объявление массива j agged.

var jagged = new[]    {

new [ ] { 1, 2, 3, 4 }, new[]    { 9, 8, 7 },

new [ ] { 11, 12, 13, 14, 15 }

};

Как видите, оператор new [ ] используется в этом объявлении двояким образом. Во-первых, этот оператор создает массив массивов. И во-вторых, он создает каждый массив в отдельности, исходя из количества инициализаторов и их типа. Как и следовало ожидать, все инициализаторы отдельных массивов должны быть одного и того же типа. Таким образом, к объявлению любого неявно типизированного ступенчатого массива применяется тот же самый общий подход, что и к объявлению обычных ступенчатых массивов.

Как упоминалось выше, неявно типизированные массивы чаще всего применяются в LINQ-ориентированных запросах. А в остальных случаях следует использовать явно типизированные массивы.

Оператор цикла f oreach

Как упоминалось в главе 5, в языке C# определен оператор цикла f oreach, но его рассмотрение было отложено до более подходящего момента. Теперь этот момент настал.

Оператор f oreach служит для циклического обращения к элементам коллекции, представляющей собой группу объектов. В C# определено несколько видов коллекций, каждая из которых является массивом. Ниже приведена общая форма оператора цикла foreach.

foreach (тип имя_переменной_цикла in коллекция) оператор;

Здесь тип имя_переменной_цикла обозначает тип и имя переменной управления циклом, которая получает значение следующего элемента коллекции на каждом шаге выполнения цикла foreach. А коллекция обозначает циклически опрашиваемую коллекцию, которая здесь и далее представляет собой массив. Следовательно, тип переменной цикла должен соответствовать типу элемента массива. Кроме того, тип может обозначаться ключевым словом var. В этом случае компилятор определяет тип переменной цикла, исходя из типа элемента массива. Это может оказаться полезным для работы с определенного рода запросами, как будет показано далее в данной книге. Но, как правило, тип указывается явным образом.

1 ... 40 41 42 43 44 45 46 47 48 ... 268
Перейти на страницу:
Тут вы можете бесплатно читать книгу C# 4.0 полное руководство - 2011 - Герберт Шилдт.
Комментарии