Чтение онлайн

ЖАНРЫ

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

Шилдт Герберт

Шрифт:

ulong Parse(string s)

UInt32

static

uint Parse(string s)

Ulntl6

static

ushort Parse(string s)

Byte

static

byte Parse(string s)

Sbyte

static

sbyte Parse(string s)

Приведенные

выше варианты метода
Parse генерируют исключение FormatException, если строка s не содержит допустимое число, определяемое вызывающим типом данных. А если она содержит пустое значение, то генерируется исключение ArgumentNullException. Когда же значение в строке s превышает допустимый диапазон чисел для вызывающего типа данных, то генерируется исключение OverflowException.

Методы синтаксического анализа позволяют без особого труда преобразовать числовое значение, введенное с клавиатуры или же считанное из текстового файла в виде строки, в соответствующий внутренний формат. В качестве примера ниже приведена программа, в которой усредняется ряд чисел, вводимых пользователем. Сначала пользователю предлагается указать количество усредняемых значений, а затем это количество считывается методом ReadLine и преобразуется из строки в целое число методом Int32 . Parse . Далее вводятся отдельные значения, преобразуемые методом Double. Parse из строки в их эквивалент типа double.

// Эта программа усредняет ряд чисел, вводимых пользователем.

using System; using System.10;

class AvgNums {

static void Main { string str; int n;

double sum = 0.0; double avg, t;

Console.Write("Сколько чисел вы собираетесь ввести: "); str = Console.ReadLine ; try {

n = Int32.Parse(str);

} catch(FormatException exc) {

Console.WriteLine(exc.Message); return;

} catch(OverflowException exc) {

Console.WriteLine(exc.Message); return;

}

Console.WriteLine("Введите " + n + " чисел."); for (int i=0; i < n ; i++) {

Console.Write(": "); str = Console.ReadLine ; try {

t = Double.Parse(str);

} catch(FormatException exc) {

Console.WriteLine(exc.Message) ; t = 0.0;

} catch(OverflowException exc) {

Console.WriteLine(exc.Message) ; t = 0;

}

sum += t;

}

avg = sum / n;

Console.WriteLine("Среднее равно " + avg);

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

Сколько чисел вы собираетесь ввести: 5 Введите 5 чисел.

: 1.1 : 2.2 : 3.3 : 4.4 : 5.5

Среднее равно 3.3

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

т.е. числовое значение с плавающей точкой, получить не удастся.

Как пояснялось выше, при неудачном исходе преобразования метод Parse сгенерирует исключение. Для того чтобы избежать генерирования исключений при преобразовании числовых строк, можно воспользоваться методом TryParse , определенным для всех числовых структур. В качестве примера ниже приведен один из вариантов метода TryParseO, определяемых в структуре Int 32:

static bool TryParse(string s, out int результат)

где s обозначает числовую строку, передаваемую данному методу, который возвращает соответствующий результат после преобразования с учетом выбираемой по умолчанию местной специфики представления чисел. (Конкретную местную специфику представления чисел с учетом региональных стандартов можно указать в другом варианте данного метода.) При неудачном исходе преобразования, например, когда параметр s не содержит числовую строку в надлежащей форме, метод TryParse возвращает логическое значение false. В противном случае он возвращает логическое значение true. Следовательно, значение, возвращаемое этим методом, обязательно следует проверить, чтобы убедиться в удачном (или неудачном) исходе преобразования.

ГЛАВА 15 Делегаты, события и лямбда-выражения

В этой главе рассматриваются три новых средства С#: делегаты, события и лямбда-выражения. Делегат предоставляет возможность инкапсулировать метод, а событие уведомляет о том, что произошло некоторое действие. Делегаты и события тесно связаны друг с другом, поскольку событие основывается на делегате. Оба средства расширяют круг прикладных задача, решаемых при программировании на С#. А лямбда-выражение представляет собой новое синтаксическое средство, обеспечивающее упрощенный, но в то же время эффективный способ определения того, что по сути является единицей исполняемого кода. Лямбда-выражения обычно служат для работы с делегатами и событиями, поскольку делегат может ссылаться на лямбда-выражение. (Кроме того, лямбда-выражения очень важны для языка LINQ, описываемого в главе 19.) В данной главе рассматриваются также анонимные методы, ковариантность, контравариантность и групповые преобразования методов.

Делегаты

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

Более того, метод можно вызывать по этой ссылке. Иными словами, делегат позволяет вызывать метод, на который он ссылается. Ниже будет показано, насколько действенным оказывается такой принцип.

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

ПРИМЕЧАНИЕ

Если у вас имеется опыт программирования на C/C++, то вам полезно будет знать, что делегат в C# подобен указателю на функцию в C/C++.

Поделиться с друзьями: