Основы программирования на Java - страница 7

Шрифт
Интервал

стр.

>System.out.println("e =” + e);

>}

>}

Исполнив этупрограмму, вы должны получить приведенный ниже результат:

>a = 2

>b = 6

>c = 1

>d = 4

>e = -4

4.1.1. Оператор деления по модулю

Оператор деления по модулю - оператор mod, обозначается символом %. Этот оператор возвращает остаток от деления первого операнда на второй. Функция mod в Java работает не только с целыми, но и с вещественными типами. Приведенная ниже программа иллюстрирует работу этого оператора.


>class Modulus {

>public static void main (String args []) {

>int x = 42;

>double у = 42.3;

>System.out.print("x mod 10 = " + x % 10);

>System.out.println("y mod 10 = " + у % 10);

>}

>}

Выполнив эту программу, вы получите следующий результат:

х mod 10 = 2 у mod 10 = 2.3

4.1.2. Арифметические операторы присваивания

Для каждого из арифметических операторов есть форма, в которой одновременно с заданной операцией выполняется присваивание. Если требуется написать а += 4, то с таким же успехом можно использовать а = а +4.

Такой способ пригоден для всех бинарных операторов, которые используются в выражениях вида:

>переменная = переменная оператор выражение;

Любой такой оператор можно записать в короткой форме:

переменная оператор = выражение;

4.1.3. Инкремент и декремент

В Java существует два оператора, называемых операторами инкремента и декремента (++ и --) и являющихся сокращенным вариантом записи для сложения или вычитания из операнда единицы. Эти операторы уникальны в том плане, что могут использоваться как в префиксной, так и в постфиксной форме. При использовании префиксной формы операнд модифицируется перед выполнением операции. В постфиксной форме сначала используется содержимое операнда, а лишь после этого операнд инкрементируется или декрементируется. Следующий пример иллюстрирует использование операторов инкремента и декремента.


>class IncDec {

>public static void main(String args[]){

>int a = 1;

>int b = 2;

>int с = ++b;

>int d = a++;

>c++;

>System.out.print("a = " + a);

>System.out.print("b = " + b);

>System.out.print("c = " + c);

>System.out.println("d = " + d);

>}

>}

Результат выполнения данной программы будет таким:

a=2b=3c=4d=1

4.2. Целочисленные битовые операторы

Для целых числовых типов данных — long, int, short, char и byte - определен дополнительный набор операторов, с помощью которых можно проверять и модифицировать состояние отдельных битов соответствующих значений. В таблице 4.2 приведена сводка таких операторов. Операторы битовой арифметики работают с каждым битом как с самостоятельной величиной.

Таблица 4.2. Операторы битовой арифметики

Оператор

Результат

Оператор

Результат

1

&

побитовое И (AND)

8

&=

Побитовое И (AND) с присваиванием

2

1

побитовое ИЛИ (OR)

9

|=

побитовое ИЛИ (OR) с присваиванием

3

^

побитовое исключающее ИЛИ (XOR)

10

^=

побитовое исключающее ИЛИ (XOR) с присваиванием

4

>>

сдвиг вправо

11

>>=

сдвиг вправо с присваиванием

5

>>>

сдвиг вправо с заполнением нулями

12

>>>=

сдвиг вправо с заполнением нулями с присваиванием

6

<<

сдвиг влево

13

<<=

сдвиг влево с присваиванием

7

~

побитовое унарное отрицание (NOT)


В таблице 4.3 показано, как каждый из операторов битовой арифметики воздействует на возможные комбинации битов своих операндов.

Таблица 4.3

А

В

OR

AND

XOR

NOT А

0

0

0

0

0


1

1

0

1

0

1


0

0

1

1

0

1


1

1

1

1

1

0


0


>Сдвиг влево

Оператор << выполняет сдвиг влево всех битов своего левого операнда на число позиций, заданное правым операндом. При этом часть битов в левых разрядах выходит за границы и теряется, а соответствующие правые позиции заполняются нулями.

>Сдвиг вправо

Оператор >> означает в языке Java сдвиг вправо. Он перемещает все биты своего левого операнда вправо на число позиций, заданное правым операндом. Когда биты левого операнда выдвигаются за самую правую позицию слова, они теряются. При сдвиге вправо освобождающиеся старшие (левые) разряды сдвигаемого числа заполняются предыдущим содержимым знакового разряда. Сделано это для того, чтобы при сдвиге вправо числа сохраняли свой знак.

>Беззнаковый сдвиг вправо

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


стр.

Похожие книги