Полное руководство. С# 4.0
Шрифт:
Следующая строка программы содержит однострочный комментарий. // Любая программа на C# начинается с вызова метода Main.
Это второй стиль комментариев, поддерживаемых в С#. Однострочный коммен тарий начинается и оканчивается символами //. Несмотря на различие стилей ком ментариев, программисты нередко пользуются многострочными комментариями для более длинных примечаний и однострочными комментариями для коротких, построч ных примечаний к программе. (Третий стиль комментариев, поддерживаемых в С#, применяется при создании документации и описывается в приложении А.) Перейдем к анализу следующей строки программы. static void Main {
Эта строка начинается с метода Main. Как упоминалось выше, в C# подпрограм
Данная строка начинается с ключевого слова static. Метод, определяемый ключе вым словом static, может вызываться до создания объекта его класса. Необходимость в этом объясняется тем, что метод Main вызывается при запуске программы. Ключе вое слово void указывает на то, что метод Main не возвращает значение. В дальней шем вы узнаете, что методы могут также возвращать значения. Пустые круглые скоб ки после имени метода Main означают, что этому методу не передается никакой ин формации. Теоретически методу Main можно передать информацию, но в данном примере этого не делается. И последним элементом анализируемой строки является символ {, обозначающий начало тела метода Main. Весь код, составляющий тело метода, находится между открывающими и закрывающими фигурными скобками. Рассмотрим следующую строку программы. Обратите внимание на то, что она на ходится внутри метода Main. Console.WriteLine("Простая программа на С#.");
В этой строке осуществляется вывод на экран текстовой строки "Простая про грамма на C#. Сам вывод выполняется встроенным методом WriteLine. В дан ном примере метод WriteLine выводит на экран строку, которая ему передается. Информация, передаваемая методу, называется аргументом. Помимо текстовых строк, метод WriteLine позволяет выводить на экран другие виды информации. Анализи руемая строка начинается с Console — имени предопределенного класса, поддержи вающего ввод-вывод на консоль. Сочетание обозначений Console и WriteLine ука зывает компилятору на то, что метод WriteLine является членом класса Console. Применение в C# объекта для определения вывода на консоль служит еще одним сви детельством объектно-ориентированного характера этого языка программирования. Обратите внимание на то, что оператор, содержащий вызов метода WriteLine, оканчивается точкой с запятой, как, впрочем, и рассматривавшаяся ранее дирек тива using System. Как правило, операторы в C# оканчиваются точкой с запятой. Исключением из этого правила служат блоки, которые начинаются символом { и оканчиваются символом }. Именно поэтому строки программы с этими символами не оканчиваются точкой с запятой. Блоки обеспечивают механизм группирования опе раторов и рассматриваются далее в этой главе.
Первый символ } в анализируемой программе завершает метод Main, а вто рой — определение класса Example.
И наконец, в C# различаются прописные и строчные буквы. Несоблюдение этого правила может привести к серьезным осложнениям. Так, если вы неумышленно на берете main вместо Main или же writeline вместо WriteLine, анализируемая про грамма окажется ошибочной. Более того, компилятор C# не предоставит возможность выполнить классы, которые не содержат метод Main, хотя и скомпилирует их. По этому если вы неверно наберете имя метода Main, то получите от компилятора со общение об ошибке, уведомляющее о том, что в исполняемом файле Example.ехе не определена точка входа. Обработка синтаксических ошибок
Если вы только начинаете изучать программирование, то вам следует научиться правильно истолковывать (и реагировать на) ошибки, которые могут появиться при попытке скомпилировать программу. Большинство ошибок компиляции возникает в результате опечаток при наборе исходного текста программы. Все программисты рано или поздно обнаруживают, что при наборе исходного текста программы очень легко сделать опечатку. Правда, если вы наберете что-нибудь неправильно, компиля тор выдаст соответствующее сообщение о синтаксической ошибке при попытке скомпи лировать вашу программу. В таком сообщении обычно указывается номер строки ис ходного текста программы, где была обнаружена ошибка, а также кратко описывается характер ошибки.
Несмотря на всю полезность сообщений о синтаксических ошибках, выдаваемых компилятором, они иногда вводят в заблуждение. Ведь компилятор C# пытается из влечь какой-то смысл из исходного текста, как бы он ни был набран. Именно по этой причине ошибка, о которой сообщает компилятор, не всегда отражает настоящую причину возникшего затруднения. Неумышленный пропуск открывающей фигурной скобки после метода Main в рассмотренном выше примере программы приводит к появлению приведенной ниже последовательности сообщений об ошибках при компиляции данной программы компилятором командной строки csc. (Аналогич ные ошибки появляются при компиляции в интегрированной среде разработки Visual Studio.) EX1.CS(12, 21) : ошибка CS1002: ; ожидалось ЕХ1.CS(13, 22) : ошибка CS1519: Недопустимая лексема '(' в объявлении члена класса, структуры или интерфейса EX1.CS(15, 1) : ошибка CS1022: Требуется определение типа или пространства имен либо признак конца файла
Очевидно, что первое сообщение об ошибке нельзя считать верным, поскольку про пущена не точка с запятой, а фигурная скобка. Два других сообщения об ошибках вно сят такую же путаницу.
Из всего изложенного выше следует, что если программа содержит синтаксиче скую ошибку, то сообщения компилятора не следует понимать буквально, поскольку они могут ввести в заблуждение. Для выявления истинной причины ошибки может потребоваться критический пересмотр сообщения об ошибке. Кроме того, полезно проанализировать несколько строк кода, предшествующих той строке, в которой об наружена сообщаемая ошибка. Иногда об ошибке сообщается лишь через несколько строк после того места, где она действительно произошла. Незначительное изменение программы
Несмотря на то что приведенная ниже строка указывается во всех примерах про грамм, рассматриваемых в этой книге, формально она не нужна. using System;
Тем не менее она указывается ради удобства. Эта строка не нужна потому, что в C# можно всегда полностью определить имя с помощью пространства имен, к которому оно принадлежит. Например, строку Console.WriteLine("Простая программа на С#.");
можно переписать следующим образом. System.Console.WriteLine("Простая программа на С#.");
Таким образом, первый пример программы можно видоизменить так. // В эту версию не включена строка "using System;". class Example { // Любая программа на C# начинается с вызова метода Main. static void Main { // Здесь имя Console.WriteLine полностью определено. System.Console.WriteLine("Простая программа на С#."); } }
Указывать пространство имен System всякий раз, когда используется член этого пространства, — довольно утомительное занятие, и поэтому большинство програм мистов на C# вводят директиву using System в начале своих программ, как это сде лано в примерах всех программ, приведенных в данной книге. Следует, однако, иметь в виду, что любое имя можно всегда определить, явно указав его пространство имен, если в этом есть необходимость. Вторая простая программа