Лабораторная работа "Выражения в программах на Си"

ЛАБОРАТОРНАЯ РАБОТА "Выражения в программах на Си"

Цель работы: Изучение стандартных операций и правил построения выражений в про­граммах на Си.

Выражения.

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

ЗАДАНИЕ 1. Определите, какие из приведенных ниже конструкций являются вы­ражениями.

1)  x + 1.5

2)  sin( x )

3)  y = x +1;

4)  127

5)  x = y = z = 0

6)  { z = 2 * cos( x ) - y; }

7)  int x = 5;

Операции.

Операции являются элементами выражений и также возвращают значение. Помимо собственно действия выполняемого операцией по вычислению значения, с каждой опера­цией связаны следующие атрибуты: арность (количество аргументов), знак операции, ее приоритет и ассоциативность. Знак операции не обязательно уникален, т. е. две операции могут иметь одно и то же обозначение. Уникальным должно быть сочетание знака и арно­сти, тогда компилятор сможет однозначно распознать операцию. Если выражение содер­жит одну операцию, например, x = 7, то ни приоритет, ни ассоциативность не важны. Если же в выражении несколько операций, компилятору необходимо знать, в каком порядке их выполнять. Например, в выражении x + 2 * y прежде должна выполняться операция ум­ножения и, затем, операция сложения. Чтобы это было так, операция умножения должна иметь более высокий приоритет, нежели операция сложения. Ассоциативность важна, ес­ли несколько операций в выражении имеют одинаковый приоритет, например, x = y = x = 0. В этом примере операции должны выполняться справа налево (правая ассоциативно­сть). В приложении представлены все стандартные операции Си, их приоритет (тем выше, чем выше уровень приоритета P), ассоциативность и арность.

НЕ нашли? Не то? Что вы ищете?

ЗАДАНИЕ 2. Определите, какими будут значения переменных i, j, k после вычис­ления значения следующего выражения:

k = ( --i + 2 * j - k++ , j-- + i - k )

если изначально эти значения были следующими:

i = 5 j = 12 k = 7 Объясните результат.

ЗАДАНИЕ 3. Напишите программу, вычисляющую значение следующего выраже­ния:

m = i /16 + j *128-17 + k *2- l /32 , если i > j + 2 * k и

m = i /16 + j *128-17 + k *2 + l /32 в противном случае,

для произвольных значений переменных i, j, k и l (ввод с помощью scanf), не ис­пользуя при этом операции умножения и деления.

ЗАДАНИЕ 4. Напишите программу, которая меняет местами последний (младший) и предпоследний байты переменной i типа int.

ЗАДАНИЕ 5. Напишите программу, которая определяет, сколько единиц содер­жится в двоичном представлении переменной типа char.

Приложение.

Приоритеты и ассоциативность операций Си. P - уровень приоритета, Ac - ассоциатив­ность, Ар - арность. ___________________________

P

Знак операции

Ac

Ар

Примечание

15

++ -- [] () . ->

à

1/2

постинкремент, постдекремент, индексирование, вызов функции, доступ к полю структуры (арность 2), доступ к полю структуры через указатель (арность 2)

14

sizeof ++ -- & * + - ~ ! (тип)

ß

1

размер в байтах, преинкремент, предекремент, получе­ние адреса, разадресация, смена знака, смена знака, побитовое отрицание, логическое отрицание, приведе­ние типа

13

* / %

à

2

умножение, деление, остаток от целочисленного деле­ния

12

+ -

à

2

сложение, вычитание

11

>> <<

à

2

побитовый сдвиг вправо, влево

10

<<=>>=

à

2

проверка на меньше, меньше или равно, больше, больше или равно

9

== !=

à

2

проверка на равенство, не равенство

8

&

à

2

побитовая конъюнкция (И)

7

^

à

2

побитовое исключающее или

6

|

à

2

побитовая дизъюнкция (ИЛИ)

5

&&

à

2

конъюнкция (логическое И)

4

||

à

2

дизъюнкция (логическое ИЛИ)

3

?:

ß

3

операция условия

2

= += -= *= /=

%= &= |= ^= <<= >>=

ß

2

операции присваивания

1

,

à

2

операция запятая