Поразрядные операторы
Поразрядные операторы И, ИЛИ, исключающее ИЛИ и НЕ обозначаются следующим образом: &, |, ^ и ~. Они выполняют те же функции, что и их логические аналоги. Но в отличие от логических операторов, поразрядные операторы действуют на уровне отдельных двоичных разрядов.
С точки зрения наиболее распространенного применения поразрядную операцию И можно рассматривать как способ подавления отдельных двоичных разрядов. Это означает, что если какой-нибудь бит в любом из операндов равен 0, то соответствующий бит результата будет сброшен в 0. Поразрядный оператор ИЛИ может быть использован для установки отдельных двоичных разрядов. Если в 1 установлен какой-нибудь бит в любом из операндов этого оператора, то в 1 будет установлен и соответствующий бит в другом операнде. Поразрядный оператор исключающее ИЛИ устанавливает двоичный разряд операнда в том и только в том случае, если двоичные разряды сравниваемых операндов оказываются разными, как в приведенном ниже примере. Для понимания вышесказaнного, разберите следующий пример:
Давайте теперь рассмотрим пример программы, использующей поразрядные операторы:
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { chet(16); provChet(8); nechet(16); Console.ReadLine(); } // Метод, преобразующий все нечетные числа в четные // в диапазоне [0, x] c помощью // поразрядного оператора & static void chet(int x) { int result; Console.WriteLine("Преобразованный диапазон чисел от 0 до {0}:\n",x); for (int i = 0; i <= x; i++) { // Сбрасываем младший разряд числа, чтобы // получить четное число result = i & 0xFFFE; Console.Write("{0}\t",result); } } // Метод, проверяющий является ли число четным static void provChet(int x) { Console.WriteLine("\n\nПроверка четности чисел в диапазоне от 1 до {0}\n",x); for (int i = 1; i <= x; i++) { if ((i & 1) == 0) Console.WriteLine("Число {0} - является четным",i); else Console.WriteLine("Число {0} - является нечетным",i); } } // Метод, преобразующий четные числа в нечетные // с помощью поразрядного оператора | static void nechet(int x) { int result; Console.WriteLine("\nПреобразованный диапазон чисел от 0 до {0}:\n",x); for (int i = 0; i <= x; i++) { result = i | 1; Console.Write("{0}\t",result); } } } }
Операторы сдвига
В C# имеется возможность сдвигать двоичные разряды, составляющие целое значение, влево или вправо на заданную величину. Ниже приведена общая форма для этих операторов:
значение << число_битов
значение >> число битов
где число_битов — это число двоичных разрядов, на которое сдвигается указанное значение.
При сдвиге влево все двоичные разряды в указываемом значении сдвигаются на одну позицию влево, а младший разряд сбрасывается в нуль. При сдвиге вправо все двоичные разряды в указываемом значении сдвигаются на одну позицию вправо. Если вправо сдвигается целое значение без знака, то старший разряд сбрасывается в нуль. А если вправо сдвигается целое значение со знаком, то разряд знака сохраняется. Напомним, что для представления отрицательных чисел старший разряд целого числа устанавливается в 1. Так, если сдвигаемое значение является отрицательным, то при каждом сдвиге вправо старший разряд числа устанавливается в 1. А если сдвигаемое значение является положительным, то при каждом сдвиге вправо старший разряд числа сбрасывается в нуль.
При сдвиге влево и вправо крайние двоичные разряды теряются. Восстановить потерянные при сдвиге двоичные разряды нельзя, поскольку сдвиг в данном случае не является циклическим. Рассмотрим пример:
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ConsoleApplication1 { class Program { static void Main(string[] args) { byte n = 6, result; // Умножить на 2 result = (byte)(n << 1); Console.WriteLine("{0} * 2 = {1}",n,result); // Умножить на 4 result = (byte)(n << 2); Console.WriteLine("{0} * 4 = {1}",n,result); // Разделить на 2 result = (byte)(n >> 1); Console.WriteLine("{0} / 2 = {1}",n,result); Console.ReadLine(); } } }
Комментарии