Полное руководство. С# 4.0
Полное руководство. С# 4.0 читать книгу онлайн
В этом полном руководстве по C# 4.0 — языку программирования, разработанному специально для среды .NET, — детально рассмотрены все основные средства языка: типы данных, операторы, управляющие операторы, классы, интерфейсы, методы, делегаты, индексаторы, события, указатели, обобщения, коллекции, основные библиотеки классов, средства многопоточного программирования и директивы препроцессора. Подробно описаны новые возможности C#, в том числе PLINQ, библиотека TPL, динамический тип данных, а также именованные и необязательные аргументы. Это справочное пособие снабжено массой полезных советов авторитетного автора и сотнями примеров программ с комментариями, благодаря которым они становятся понятными любому читателю независимо от уровня его подготовки.Книга рассчитана на широкий круг читателей, интересующихся программированием на C#.
В данной книге вы найдете:- Полное описание средств языка C#- Подробное рассмотрение новых средств в версии C# 4.0, в том числе PLINQ, библиотеку TPL, именованные и необязательные аргументы, динамический тип данных и многое другое- Сотни простых и понятных примеров программ с комментариями.- Самый полный источник информации по C#Благодаря поддержке параллельного языка интегрированных запросов (PLINQ) и библиотеки распараллеливания задач (TPL) версия 4.0 стала новой вехой в программировании на C#, и поэтому Герберт Шилдт, автор лучших книг по программированию, обновил и расширил свое классическое руководство, чтобы охватить в нем эти и другие нововведения. В книге подробно описываются языковые средства C#, даются профессиональные рекомендации и приводятся сотни примеров программ, охватывающих все аспекты программирования на C#, включая синтаксис, ключевые слова и основные библиотеки, не говоря уже о таких новшествах, как PLINQ, TPL, динамический тип данных, а также именованные и необязательные аргументы.Это необходимое каждому программирующему на C# справочное руководство написано простым и доступным языком, благодаря которому Герберт Шилдт стал таким популярным. В книге найдут ответы на насущные вопросы по C# как начинающие, так и опытные программисты.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
Кроме того, время создания файла можно выяснить, вызвав метод GetCreationTime(),а время последней записи в файл, вызвав метод GetLastWriteTime(). Имеются также варианты этих методов для представления данных о файле в формате всеобщего скоординированного времени (UTC). Попробуйте поэкспериментировать с ними.Преобразование числовых строк в их внутреннее представление
Прежде чем завершить обсуждение темы ввода-вывода, рассмотрим еще один способ, который может пригодиться при чтении числовых строк. Как вам должно бытьуже известно, метод WriteLine() предоставляет удобные средства для вывода различных типов данных на консоль, включая и числовые значения встроенных типов, например int или double. При этом числовые значения автоматически преобразуютсяметодом WriteLine() в удобную для чтения текстовую форму. В то же время аналогичный метод ввода для чтения и преобразования строк с числовыми значениямив двоичный формат их внутреннего представления не предоставляется. В частности,отсутствует вариант метода Read() специально для чтения строки "100", введенной склавиатуры, и автоматического ее преобразования в соответствующее двоичное значение, которое может быть затем сохранено в переменной типа int. Поэтому даннуюзадачу приходится решать другими способами. И самый простой из них — воспользоваться методом Parse(), определенным для всех встроенных числовых типов данных.
Прежде всего необходимо отметить следующий важный факт: все встроенные в C#типы данных, например int или double, на самом деле являются не более чем псевдонимами (т.е. другими именами) структур, определяемых в среде .NET Framework.В действительности тип в C# невозможно отличить от типа структуры в среде .NETFramework, поскольку один просто носит имя другого. В C# для поддержки значенийпростых типов используются структуры, и поэтому для типов этих значений имеютсяспециально определенные члены структур.
Ниже приведены имена структур .NET и их эквиваленты в виде ключевых слов C#для числовых типов данных.Имя структуры в .NETИмя типа данных в C#DecimaldecimalDoubledoubleSinglefloatInt16shortInt32intInt64longUInt16ushortUInt32uintUint64ulongBytebyteSbytesbyte
Эти структуры определены в пространстве имен System. Следовательно, имя структуры Int32 полностью определяется как System.Int32. Эти структуры предоставляют обширный ряд методов, помогающих полностью интегрировать значения простыхтипов в иерархию объектов С#. А кроме того, в числовых структурах определяется статический метод Parse(), преобразующий числовую строку в соответствующий двоичный эквивалент.
Существует несколько перегружаемых форм метода Parse(). Ниже приведены егопростейшие варианты для каждой числовой структуры. Они выполняют преобразование с учетом местной специфики представления чисел. Следует иметь в виду, что каждый метод возвращает двоичное значение, соответствующее преобразуемой строке.СтруктураМетод преобразованияDecimalstatic decimal Parse(string s)Doublestatic double Parse(string s)Singlestatic float Parse(string s)Int64static long Parse(string s)Int32static int Parse(string s)Intl6static short Parse(string s)UInt64static ulong Parse(string s)UInt32static uint Parse(string s)Ulnt16static ushort Parse(string s)Bytestatic byte Parse(string s)Sbytestatic sbyte Parse(string s)
Приведенные выше варианты метода Parse() генерируют исключениеFormatException, если строка s не содержит допустимое число, определяемое вызывающим типом данных. А если она содержит пустое значение, то генерируется исключение ArgumentNullException. Когда же значение в строке s превышает допустимый диапазон чисел для вызывающего типа данных, то генерируется исключениеOverflowException.
Методы синтаксического анализа позволяют без особого труда преобразовать числовое значение, введенное с клавиатуры или же считанное из текстового файла в видестроки, в соответствующий внутренний формат. В качестве примера ниже приведенапрограмма, в которой усредняется ряд чисел, вводимых пользователем. Сначала пользователю предлагается указать количество усредняемых значений, а затем это количество считывается методом ReadLine() и преобразуется из строки в целое число методом Int32.Parse(). Далее вводятся отдельные значения, преобразуемые методомDouble.Parse() из строки в их эквивалент типа double.// Эта программа усредняет ряд чисел, вводимых пользователем.using System;using System.IO;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(), определенным для всех числовых структур. В качестве примера ниже приведен один из вариантов метода TryParse(), определяемых в структуре Int32:static bool TryParse(string s, out int результат)
где s обозначает числовую строку, передаваемую данному методу, который возвращает соответствующий результат после преобразования с учетом выбираемой поумолчанию местной специфики представления чисел. (Конкретную местную специфику представления чисел с учетом региональных стандартов можно указать в другомварианте данного метода.) При неудачном исходе преобразования, например, когдапараметр s не содержит числовую строку в надлежащей форме, метод TryParse()возвращает логическое значение false. В противном случае он возвращает логическоезначение true. Следовательно, значение, возвращаемое этим методом, обязательноследует проверить, чтобы убедиться в удачном (или неудачном) исходе преобразования.
ГЛАВА 15. Делегаты, события и лямбда-выражения
В этой главе рассматриваются три новых средства С#:делегаты, события и лямбда-выражения. Делегатпредоставляет возможность инкапсулировать метод,а событие уведомляет о том, что произошло некотороедействие. Делегаты и события тесно связаны друг с другом,поскольку событие основывается на делегате. Оба средстварасширяют круг прикладных задача, решаемых при программировании на С#. А лямбда-выражение представляетсобой новое синтаксическое средство, обеспечивающееупрощенный, но в то же время эффективный способ определения того, что по сути является единицей исполняемогокода. Лямбда-выражения обычно служат для работы с делегатами и событиями, поскольку делегат может ссылаться налямбда-выражение. (Кроме того, лямбда-выражения оченьважны для языка LINQ, описываемого в главе 19.) В даннойглаве рассматриваются также анонимные методы, ковариантность, контравариантность и групповые преобразованияметодов.Делегаты
Начнем с определения понятия делегата. Попросту говоря, делегат представляет собой объект, который можетссылаться на метод. Следовательно, когда создается делегат,то в итоге получается объект, содержащий ссылку на метод.Более того, метод можно вызывать по этой ссылке. Инымисловами, делегат позволяет вызывать метод, на который онссылается. Ниже будет показано, насколько действеннымоказывается такой принцип.