Алфавит и основные понятие

Забаненный
Статус
Оффлайн
Регистрация
30 Июл 2016
Сообщения
267
Реакции[?]
55
Поинты[?]
0
Обратите внимание, пользователь заблокирован на форуме. Не рекомендуется проводить сделки.
1. Алфавит
Множество символов языка C включает:




  • прописные буквы латинского алфавита;
  • строчные буквы латинского алфавита;
  • арабские цифры;
  • разделители: , . ; : ? ! ' " | / \ ~ _ ^ ( ) { } [ ] < > # % & - = + *

Остальные символы могут быть использованы только в символьных строках, символьных константах и комментариях. Язык C++ различает большие и маленькие буквы, таким образом, name и Name – разные идентификаторы.

2. Литералы

Литералы в языке C++ могут быть целые, вещественные, символьные и строковые
.



  • Целые:
    • десятичные: 10, 132, -32179;
    • восьмеричные (предваряются символом «0»): 010, 0204, -076663;
    • шестнадцатеричные (предваряются символами «0х»): 0хА, 0x84, 0x7db3.
  • Вещественные: 15.75, 1.575e1, .75, -.125
  • Символьные: 'a', 'e', '.', '?', '2'.
  • Строковые: "строка".




  • ( ) – выражение в скобках (используется для изменения порядка вычисления) или вызов функции.
  • [ ] – индексное выражение, используется для работы с
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    .
  • . и -> – выбор элемента, используются при работе с
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    ,
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    и
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    .
  • Операции static_cast (преобразование с проверкой во время компиляции), dynamic_cast (преобразование с проверкой во время выполнения),reinterpret_cast (преобразование без проверки), const_cast(константное преобразование) осуществляют различные преобразования типов. Они имеют следующий синтаксис:операция<новый тип>(выражение). Угловые скобки являются элементом синтаксиса. Операцияstatic_castосуществляет преобразование родственных типов, например, указателя на один тип к указателю на другой тип из той же иерархии классов, целый тип в перечисление или тип с плавающей точкой в интегральный. Операция reinterpret_cast управляет преобразованиями между несвязанными типами, например, целых в указатели или указателей в другие (несвязанные) указатели. Такое различие позволяет компилятору осуществлять минимальную проверку типов при использовании static_cast, а программисту – легче обнаружить опасные преобразования, представляемые reinterpret_cast. Преобразованиеdynamic_cast выполняется и проверяется на этапе выполнения. Преобразование const_castаннулирует действие модификатора
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    .
  • - – унарный минус.
  • ~ – обратный код (см.
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    ).
  • ! – логическое отрицание.
  • * – косвенная адресация (см.
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    ).
  • & – адресация (см.
    Пожалуйста, авторизуйтесь для просмотра ссылки.
    ).
  • Операции ++ и -- инкрементируют (увеличивают на 1) и декрементируют (уменьшают на 1) свой операнд. Операнд должен иметь целый, вещественный тип или быть указателем. Операции инкремента и декремента могут записываться как перед своим операндом (префиксная форма записи), так и после него (постфиксная форма записи). При префиксной форме записи операнд сначала инкрементируется или декрементируется, а затем его новое значение участвует в дальнейшем вычислении выражения, содержащего данную операцию. При постфиксной форме записи операнд инкрементируется или декрементируется лишь после того, как его старое значение участвует в вычислении выражения. Таким образом, результатом операций инкремента и декремента является либо новое, либо старое значение операнда. Например, если переменная i = 0, то выражение a[++i] = 1 меняет элемент a[1], а выражение a[i++] = 1 меняет элемент a[0]. В обоих случая переменная i получает новое значение, равное 1.
  • sizeof – вычисление размера в байтах переменной или типа.
  • Операция приведения типа записывается следующим образом: (<новый тип>)<выражение>. Например, (long int)n приводит переменную n к типу long int. При преобразовании типов надо помнить, что при преобразовании между знаковыми/беззнаковыми значениями и при преобразовании от типа с большей размерностью к типу с меньшей размерностью могут возникнуть ошибки. Более безопасным способом преобразования типов является использование операций static_cast, dynamic_cast, reinterpret_cast иconst_cast.
  • % – остаток от деления.
  • В языке C++ имеется одна тернарная операция – условная операция. Она имеет следующий синтаксис: <операнд 1> ? <операнд 2> : <операнд 3>. Если <операнд 1> имеет ненулевое значение, то вычисляется <операнд 2> и результатом условной операции является его значение. Если же <операнд 1> равен нулю, то вычисляется <операнд 3> и результатом является его значение. В любом случае вычисляется только один из операндов, <операнд 2> или <операнд 3>, но не оба.
  • Простое присваивание. Операция простого присваивания обозначается знаком «=». Значение правого операнда присваивается левому операнду. Операция вырабатывает результат, который может быть далее использован в выражении. Результатом операции является присвоенное значение. Например, выражение a = b = c = 0 присваивает всем переменным значение 0, а в результате вычисления выражения a = (b = 3) + (c = 5) переменная c будет иметь значение 5, переменная b будет иметь значение 3, и переменная a будет иметь значение 8.
  • Составное присваивание. Операция составного присваивания состоит из простой операции присваивания, скомбинированной с какой-либо другой бинарной операцией. При составном присваивании вначале выполняется действие, специфицированное бинарной операцией, а затем результат присваивается левому операнду. Оператор n += 5 эквивалентен оператору n = n + 5, но при этом первый оператор легче для понимания и выполняется быстрее.
  • Операция последовательного вычисления «,» обычно используется для вычисления нескольких выражений в ситуациях, где по синтаксису допускается только одно выражение. Однако, запятая, разделяющая параметры функции, не является операцией последовательного вычисления.


  • [*]Порядок вычислений подвыражений внутри выражений не определён. В частности, не стоит предполагать, что выражения вычисляются слева направо.

    int x = f(2) + g(3); // Неизвестно, какая функция вызовется первой – f() или g()
    При отсутствии ограничений на порядок вычислений можно сгенерировать более качественный код. Однако отсутствие ограничений на порядок вычислений может привести к неопределённым результатам.

    Логические операции «И» и «ИЛИ», условная операция и операция последовательного вычисления гарантируют определенный порядок вычисления своих операндов. Условная операция вычисляет сначала свой первый операнд, а затем, в зависимости от его значения, либо второй, либо третий операнд. Логические операции также обеспечивают вычисление своих операндов слева направо, причём логические операции вычисляют минимальное число операндов, необходимое для определения результата выражения. Таким образом, второй операнд выражения может вообще не вычисляться. Операция последовательного вычисления обеспечивает вычисление своих операндов по очереди, слева направо. Обратите внимание, что запятая в качестве указателя последовательности логически отличается от запятой, используемой в качестве разделителя параметров при вызове функций.

    f1(v, i++);
    f2((v, i++));// Два параметра
    // Один параметр
    Вызов функции f1 осуществляется с двумя параметрами v и i++, и порядок вычисления параметров не определён. Расчет на определённый порядок вычисления параметров является исключительно плохим стилем и приводит к непредсказуемому поведению программы. Вызов функции f2 имеет один параметр – последовательность выражений, разделённых запятой. Порядок вычисления гарантирован, и вызов эквивалентен f2(i++).
 
Сверху Снизу