Sar операнд,счетчик_сдвигов
арифметический сдвиг влево/вправо. Содержимое операнда сдвигается влево/ вправо на количество битов, определяемое значением счетчик_сдвигов. Справа/ Слева в операнд вписываются нули. Команда sal не сохраняет знака, но устанавливает флаг cf в случае смены знака очередным выдвигаемым битом. В остальном команда sal полностью аналогична команде shl; Команда sar сохраняет знак, восстанавливая его после сдвига каждого очередного бита.
Команды циклического сдвига rol операнд, счетчик _ сдвигов (Rotate Left) — циклический сдвиг влево. Содержимое операнда сдвигается влево на количество бит, определяемое операндом счетчик_сдвигов. Сдвигаемые влево биты записываются в тот же операнд справа. ror операнд,счетчик_сдвигов (Rotate Right) — циклический сдвиг вправо.
Как видно из рис., команды простого циклического сдвига в процессе своей работы осуществляют одно полезное действие, а именно: циклически сдвигаемый бит не только вдвигается в операнд с другого конца, но и одновременно его значение становиться значением флага cf. Команды циклического сдвига через флаг переноса cf отличаются от команд простого циклического сдвига тем, что сдвигаемый бит не сразу попадает в операнд с другого его конца, а записывается сначала в флаг переноса cf. Лишь следующее исполнение данной команды сдвига (при условии, что она выполняется в цикле) приводит к помещению выдвинутого ранее бита с другого конца операнда (см. рис. 4). rcl операнд,счетчик_сдвигов (Rotate through Carry Left) — циклический сдвиг влево через перенос. Содержимое операнда сдвигается влево на количество бит, определяемое операндом счетчик_сдвигов. Сдвигаемые биты поочередно становятся значением флага переноса cf.
rcr операнд,счетчик_сдвигов (Rotate through Carry Right) — циклический сдвиг вправо через перенос. Содержимое операнда сдвигается вправо на количество бит, определяемое операндом счетчик_сдвигов. Сдвигаемые биты поочередно становятся значением флага переноса cf.
Из рис. 4 видно, что при сдвиге через флаг переноса появляется промежуточный элемент, с помощью которого, в частности, можно производить подмену циклически сдвигаемых битов, в частности, рассогласование битовых последовательностей. Под рассогласованием битовой последовательности здесь и далее подразумевается действие, которое позволяет некоторым образом локализовать и извлечь нужные участки этой последовательности и записать их в другое место Пример. Дано отрицательное число. Выведите на экран его значение по модулю деленное на 2. Любое отрицательное число хранится в дополнительном формате -1 ffh -2 feh … -10 f6h получить значение числа по модулю, можно осуществив логическое отрицание над числом и добавив 1.
Model small Stack 100h Data x db -12 Code start: mov ax,@data Mov ds,ax
mov al,x;в al отрицательное число not al inc al ;число по модулю shr al,1 ;выводим результат на экран
aam; ;преобразование двоичного числа меньшего 63h (9910), которое находится в al в его;неупакованный BCD-эквивалент ; -разделить значение регистра al на 10; ; -записать частное в регистр ah, остаток — в регистр al.
mov dx,ax;число в регистр dx or dx,3030h;получаю ASCII код числа xchg dh,dl;меняю местами старший и младший байт, для вывода символа из dl mov ah,02h ; int 21h;вывожу старшую половинку числа xchg dh,dl;меняю местами старший и младший байт, int 21h;вывожу младшую половинку числа
Mov ax,4c00h Int 21h End start
Воспользуйтесь поиском по сайту: ©2015 - 2024 megalektsii.ru Все авторские права принадлежат авторам лекционных материалов. Обратная связь с нами...
|