C# для профессионалов. Том II
Шрифт:
Этот код задает
Обычное использование такого синтаксиса состоит в вычислении некоторого условия внутри инструкции
Этот код выглядит пугающим на первый взгляд, но он вполне логичен. Давайте разберем его. Прежде всего компьютер проверяет условие
Тернарный оператор
В этом приложении нет места для обсуждения всех доступных в C# операторов. Они подробно рассмотрены в главах 3-6. Однако упомянем тернарный оператор (известный также как условный оператор), так как он имеет очень необычный синтаксис. Тернарный оператор формируется из двух символов —
и работает так: оценивается первое выражение, которое расположено перед символом
что будет иметь такой же результат, как и следующие вычисления:
Заключение
В этом приложении было представлено краткое введение в C# с точки зрения сравнения его с Visual Basic. Мы обнаружили довольно мало различий в синтаксисе. В целом синтаксис C# позволяет выразить большинство инструкций более компактным образом. Также можно заметить большое сходство между языками, например в их использовании классов (или модулей классов в VB), типов данных значений, ссылочных типов данных и многих синтаксических структур. Однако C# поддерживает также многие мощные свойства, в частности связанные с наследованием и классическим объектно-ориентированным программированием, которые недоступны в VB.
Выполнение перехода от VВ к C# требует специальной подготовки, но стоит того, так как методология C# позволяет не только кодировать приложения, которые можно сделать в VB но также множество других приложений которые было бы трудно или невозможно создать в VB хорошо структурированными и легко поддерживаемыми. При использовании C# можно также получить дополнительный бонус среды выполнения .NET и всех связанных с этим преимуществ.
Приложeниe D
Параметры компиляции C#
Это приложение перечисляет различные параметры компиляции C#, которые можно применять, если необходимо компилировать проекты C#, не используя возможности Visual Studio.NET, или если необходимо выполнить операции компилятора, не поддерживаемые Visual Studio.NET. Они организованы как последовательность таблиц, составленных согласно категориям.
Первая таблица показывает различные форматы файлов, которые может выводить компилятор:
Параметр | Назначение |
---|---|
/doc:<имя файла> | Обрабатывает комментарии документации XML (помеченные тремя слэшами — /// ) и выводит в указанный файл XML. |
/nooutput | Компилирует код, но не создает файла вывода; полезно для отладочных целей, так как консоль будет показывать предупреждения и ошибки. |
/out:<имя файла> | Определяет имя файла вывода. Если оно не указано, то компилятор создает стандартный файл .exe с тем же именем, что и у исходного файла (кроме расширения). |
/target:<option> /t:<option> | Определяет формат файла вывода в одном из четырех вариантов: exe : создает стандартный исполняемый файл (задание по умолчанию). library : создает код библиотеки (DLL). module : создает модуль кода (сборку без манифеста), который позже добавляется к сборке (с помощью /addmodule ). winexe : создает исполняемый файл для Windows. |
Если только не определен параметр
Следующая таблица объясняет параметр командной строки для определения оптимизации компилятора.
Параметр | Назначение |
---|---|
/optimize<+ | -> /о<+ | -> | Включает или выключает оптимизацию, выполняемую компилятором для создания более короткого, быстрого и эффективного вывода. Отключено по умолчанию. Чтобы включить, применяйте синтаксис: /optimize или /optimize+ Чтобы выключить, применяйте синтаксис: /optimize- |
Следующая таблица описывает параметры, которые используются, когда создают и ссылаются на сборки .NET.
Параметр | Назначение |
---|---|
/addmodule:<модуль> | Определяет один или несколько модулей, которые будут включены в указанную сборку. Если модулей более одного, то они разделяются с помощью точки с запятой. Этот параметр недоступен в Visual Studio.NET |
/nostdlib<+ | -> | Определяет, нужно или нет импортировать стандартную библиотеку ( mscorlib.dll ), которая импортируется по умолчанию. Если желательно реализовать свое собственное пространство имен и классы System , то компилятор не будет загружать стандартную библиотеку. Синтаксис для этого выглядит следующим образом: /nostdlib или /nostdlib+ Синтаксис для импортирования следующий: /nostdlib- |
/reference:<сборка> /r:<сборка> | Импортирует метаданные из файла сборки. Можно определить полный путь доступа к сборке, или определенный везде с помощью переменной окружения PATH , либо относительный путь начинающийся в текущем проекте. Если имеется больше одного файла, они разделяются посредством точки с запятой. |
Следующая таблица объясняет параметры, которые применяются при отладке и контроле ошибок.
Параметр | Назначение |
---|---|
/bugreport <имя файла> | Создает указанный файл, который содержит всю информацию об ошибках, выданную компилятором. Содержимое файла включает: копию всего исходного кода, листинг параметров компилятора, информацию о версии компилятора, операционной системе и т.д., всю выдачу компилятора, описание проблемы и возможное решение (по желанию). Эта возможность недоступна в Visual Studio.NET. |
/checked<+ | -> | Определяет, даст ли превышение над заданным значением целого числа ошибку времени выполнения. Это применимо только к коду вне области действия блоков checked и unchecked . Отключено по умолчанию. Синтаксис для контроля переполнения следующий: /checked или /checked+ . Чтобы отключить контроль переполнения, используйте следующий синтаксис: /checked- |
/debug<+ | -> /debug:<option> | Создает информацию отладки. Чтобы включить, используйте синтаксис: /debug или /debug+ . Чтобы отключить, используйте: /debug- . Отладка отключена по умолчанию. Если определить, что должна выводиться информация отладки, то имеются две возможности в отношении типа создаваемой информации отладки: /debug:full : разрешает соединение отладчика с операционной системой. /Debug:pdbonly : разрешает отладку исходного кода, когда программа запускается в отладчике, но будет выводить только ассемблерный код, когда выполняющаяся программа присоединяется к отладчику. |
/fullpaths | Определяет полный путь доступа к файлу, содержащему ошибку. Эта возможность недоступна в Visual Studio.NET. |
/nowarn:<number> | Подавляет способность компилятора создавать специальные предупреждения. Параметр number определяет, какой номер предупреждения подавить. Если определено более одного, то они разделяются запятыми. Это параметр недоступен в Visual Studio.NET. |
/warn:<option> /w:<option> | Задает минимальный уровень предупреждений, который желательно выводить. Параметр option показывает: 0: Подавление всех предупреждений. 1: Вывод только серьезных предупреждений. 2: Вывод серьезных предупреждений и предупреждений среднего уровня. 3: Вывод серьезных предупреждений, предупреждений среднего и низкого уровня. 4: Вывод всех сообщений, включая информационные предупреждения |
/warnaserror<+ | -> | Интерпретирует все предупреждения как ошибки. Чтобы включить, используйте синтаксис: /warnaserror или /warnaserror+ . Чтобы отключить, используйте синтаксис: /warnaserror- . Отключено по умолчанию. |