Шаг 77.
Побитовые операции. Строковые операнды

    На этом шаге мы рассмотрим использование битовых операций для строковых операндов.

    Если оба операнда являются строковыми литералами или переменными, содержащими строковые данные, то операции побитового логического сравнения сравнивают соответствующие биты кода каждого символа строки. Для кодирования символов используется таблица ASCII-кодов. Если строки разной длины, то при сравнении полагается, что строка меньшей длины содержит необходимое число недостающих символов с восьмеричным кодом \000. Например, результатом сравнения двух строк "++" и "3" с помощью операции | побитового логического ИЛИ будет строка ";+". Операнды этой операции представляются следующими битовыми последовательностями (каждый символ представляется 8 битами):

00101011 00101011 # Восьмеричный код символа "+" равен 053. 
00110011          # Восьмеричный код символа "3" равен 063.

    Вторая строка дополняется восемью нулевыми битами и последовательно для каждой пары соответствующих бит двух строк одинаковой длины выполняется операция логического ИЛИ. Результатом выполнения этой процедуры является битовая последовательность

    00111011  00101011

    При ее интерпретации как строки символов получается последовательность двух символов с восьмеричными кодами 073 и 053, которые соответствуют символам ";" и "+".

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

  45.93 | 100     #  Результат: число 109.
  "45.93" | 100   #  Результат: число 109.
  45.93 | "100"   #  Результат: число 109.
  "45.93" | "100" # Результат: строка   "55>93".

    В первых трех операциях этого примера строки преобразуются в числа, а потом выполняется соответствующая операция побитового логического ИЛИ двух чисел.

    Выполнение операции побитового логического отрицания ~ для строки ничем не отличается от соответствующей операции отрицания для чисел с той лишь разницей, что применяется она к битовому представлению символов строки:

  ~"1"  # Результат: "+". 
  ~"ab" # Результат: "ЮЭ".

    На следующем шаге мы рассмотрим операции присваивания.




Предыдущий шаг Содержание Следующий шаг