Читать «Java 7 (Наиболее полное руководство)» онлайн - страница 26
Ильдар Шаукатович Хабибуллин
□ ~b2 == 98, двоичное представление — 0...01100010;
□ b1 & b2 == 16, двоичное представление — 0...00010000;
□ b1 | b2 == -65, двоичное представление — 1...10111111;
□ b1 Л b2 == -81, двоичное представление — 1...10101111.
Двоичное представление каждого результата занимает 32 бита.
Заметьте, что дополнение ~x всегда эквивалентно разности (-x) -1.
Сдвиги
В языке Java есть три операции сдвига двоичных разрядов:
□ сдвиг влево — <<;
□ сдвиг вправо — >>;
□ беззнаковый сдвиг вправо — >>>.
Эти операции своеобразны тем, что левый и правый операнды в них имеют разный смысл. Слева стоит значение целого типа, а правая часть показывает, на сколько двоичных разрядов сдвигается значение, стоящее в левой части.
Например, операция b1 << 2 сдвинет влево на 2 разряда предварительно повышенное значение 0...00110010 переменной b1, что даст в результате 0...011001000, десятичное число — 200. Освободившиеся справа разряды заполняются нулями; левые разряды, находящиеся за 32-м битом, теряются.
Операция b2 << 2 сдвинет повышенное значение 1...10011101 на два разряда влево. В результате получим 1...1001110100, десятичное значение--396.
Заметьте, что сдвиг влево на n разрядов эквивалентен умножению числа на 2 в степени n.
Операция b1 >> 2 даст в результате 0...00001100, десятичное — 12, а b2 >> 2 — результат
1...11100111, десятичное--25, т. е. слева распространяется старший бит, правые биты
теряются. Это так называемый
Операция беззнакового сдвига во всех случаях ставит слева на освободившиеся места нули, осуществляя
Если же мы хотим получить логический сдвиг исходного значения 10011101 переменной b2, т. е. 0...00100111, надо предварительно наложить на b2
(b2 & 0xFF) >>> 2.
Будьте осторожны при использовании сдвигов вправо.
Упражнения
3. Каково значение выражения ' D' + 5?
При определениях, сделанных ранее, вычислите выражения:
4. (b1 + с1) % (++b2 / b1++).
5. (b1 < с1) && (b2 == -99) || (ind >= 0).
6. (b1 | с1) & (big Л b1).
7. (b1<<3 + с1<<2) % (b2>>5 / b1>>>2).
Вещественные типы
Вещественных типов в Java два: float и double. Они характеризуются разрядностью, диапазоном значений и точностью представления, отвечающим стандарту IEEE 7541985 с некоторыми изменениями. К обычным вещественным числам добавляются еще три значения:
□ положительная бесконечность, выражаемая константой positive_infinity и возникающая при переполнении положительного значения, например в результате операции умножения 3.0*6e307 или при делении на нуль;