Студопедия

Главная страница Случайная страница

Разделы сайта

АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника






Операции и выражения






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

Операции делятся на унарные, которые выполняются над одним операндом, и бинарные – над двумя операндами.

Унарные операции:

& операция получения адреса операнда;
‘*’ операция обращения по адресу;
‘-‘ унарный минус, изменяет знак арифметического операнда;
+ унарный плюс, введен для симметрии с унарным минусом;
~ инвертирует значение каждого бита операнда;
! НЕ – логическое отрицание операнда;
++ увеличение на 1. Эта операция имеет две формы – префиксная операция и постфиксная. Префиксная – увеличение значения операнда на 1 до его использования. Постфиксная – увеличение значения операнда на 1 после его использования;
-- уменьшение на 1;
sizeof операция вычисления размера (в байтах) для объекта того типа, который имеет операнд;

Бинарные операции

Аддитивные
+ бинарный плюс;
- бинарный минус;
* умножение операндов арифметического типа;
/ деление операндов арифметического типа. При целочисленных операндах абсолютное значение результата округляется до целого;
% получение остатка от деления целочисленных операндов. При неотрицательных операндах остаток положительный. В противном случае – зависит от компилятора. В нашем случае 13%-4 равно 1, а -13%4 равно -1
Операции сдвига
< < Операции сдвига < < и > > выполняют сдвиг левого операнда влево или вправо на количество разрядов, заданное правым операндом. Таким образом, выражение х < < 2 сдвигает х влево на 2 разряда; это эквивалентно умножению х на 4. Таким образом, операции сдвига могут применяться для деления или умно­жения целого значения на число, равное степени 2.
> >
Поразрядные операции (битовые) Работают в двоичной системе
& x& y Поразрядная коньюнкция (И) битовых представлений целочисленных операндов. Каждый бит результата будет содержать 1, если в соответствующих битах операндов тоже стоят 1. Например 10& 15 (1010& 1111) будет 10 (1010)
| Поразрядная дизъюнкция (битовое ИЛИ). Каждый бит результата будет содержать 1, если хотя бы в одном из соответствующих битов операндов стоит 1. Например 10|15 (1010|1111) будет 15 (1111)
^ Поразрядное исключающее ИЛИ. Каждый бит результата будет содержать 1, если только в одном из соответствующих битов операндов стоит 1. Например 10^15 (1010^1111) будет 5 (0101)
Операции отношений (сравнения)
< 1) Используются для сравнения значений. Результат целочисленный – 0(ложь) или 1(истина). Примеры операций отношения: int a, b, i, n; float с, d; а = d > с; b = i + n < 100;  
>
< =
> =
==
! =
Логические бинарные операции
& & Коньюнкция арифметических операндов. Результат целочисленный – 0(ложь) или 1(истина)
|| Дизъюнкция арифметических операндов. Результат целочисленный – 0(ложь) или 1(истина)
  Операндами этих логических операций могут быть результаты выражений любого типа. Но перед выполнением логических операций значения результатов выражений-операндов преобразуются в логические значения исти­на - 1 или ложь - 0. Все значения, отличные от 0, интерпретируются как ис­тинные - 1, а если значение равно 0, то оно ложно. Результат логической oneрации равен 1, если логическое выражение истинно, и результат равен 0, если логическое выражение ложно. Таблица 3. Результат логических операций

 

 

Операнд-1 Операнд-2 Результат операций
! & & ||
         
         
         
         

 

Операции присваивания
= Простое присваивание: присвоить значение выражения-операнда из правой части операнду левой части. p=10.3-2*x С помощью одного оператора присваивания могут получить новое значение несколько переменных. Например, переменные а, b, с, е получат значение, рав­ное нулю: а = b = с = е = 0; В одном операторе операция присваивания может использоваться несколько раз. Например: а = (b = с) * d; здесь сначала переменной b присваивается значение переменной с, а затем вычисляется выражение b*d и результат присваивается переменной а.
*= Присваивание после умножения: присвоить операнду левой части произведение значений обоих операндов. То есть p*=2 эквивалентно p=p*2
/= Присваивание после деления. p/=2-x эквивалентно p=p/(2-x)
%= Присваивание после деления по модулю. присвоить операнду левой части остаток от целочисленного деления значения левого операнда на значение правого. p%=3 эквивалентно p=p%3
+= Присваивание после суммирования
-= Присваивание после вычитания. p-=4-z эквивалентно p=p-(4-z)
& = Присваивание после поразрядной коньюнкции. e& =44 Û e=e& 44
|= Присваивание после поразрядной дизъюнкции. e|=c Û e=e|c
^= Присваивание после поразрядного исключающего ИЛИ
< < = Присваивание после сдвигов разрядов влево. a< < =4 Û a=a< < 4
> > = Присваивание после сдвигов разрядов вправо
Операции выбора компонентов структурированного объекта
. (точка) Используются со сложными типами данных – структурами и объединениями.
->
Запятая в качестве операции
, Несколько выражений, разделенных запятыми вычисляются слева направо. В качестве результата – значение и тип самого правого выражения. Например: int a, b; a=(b=3, 3*b) printf(“%d”, a) //даст результат 9  
Скобки
(), [] Играют роль бинарных операций при вызове функций и индексировании элементов массива.
Условная трехместная операция
?: Используется с тремя операндами (тернарная). Синтаксис: Выражение1? выражение2: выражение3 Первым вычисляется значение выражения1. Если оно истинно, то есть не равно 0, то вычисляется значение выражения 2, которое и становится результатом. Если при высичлении выражения1 получится 0, то вычисляется и берется в качестве результата выражение3. Пример: x< 0? -x: x // выражение возвращает абсолютную величину x

При выполнении смешанных выражений ав­томатически производится преобразование операндов к одному типу в соответ­ствии с приоритетами. Ниже приведен порядок следования типов по возрастанию их старшинства:

char< int< long< float< double

Автоматически выполняются следующие преобразования типов:

1. char преобразуется в int, float в double

2. если старшим типом является double, то все остальные типы преобразуются в double. Таким же будет и тип результата.

3. если старшим типом является long, то все остальные типы преобразуются в long. Таким же будет и тип результата.

4. если старшим типом является unsigned, то все остальные типы преобразуются в unsigned. Таким же будет и тип результата.

Если не выполняется ни одно из предыдущих условий и выражение содержит значение типа int, то результат будет int. Существует одно исключение из этих правил. Если выражение содержит типы long и unsigned, то unsigned не преобразуется к long. Типом результата будет usigned long.

Часто возникают ситуации, когда желательно вместо целых значений использовать вещественные.

Рассмотрим пример:

 

int x, y;

float z;

x=10;

y=100;

z=x/y;

 

В результате вычислений переменная z получит значение 0 как целое число, а не 0.1 как вещественное. В подобных ситуациях часто прибегают к явному преобразованию типов с помощью сле­дующей конструкции:

 

(имя-типа) выражение

 

где тип –корректный тип данных С. Например, для получения правильного значения при вычислении выражения a/b, где a и b целые числа необходимо преобразовать результат к типу float:

(float)a/b;






© 2023 :: MyLektsii.ru :: Мои Лекции
Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав.
Копирование текстов разрешено только с указанием индексируемой ссылки на источник.