Рубрики
Справочник по ассемблеру

ADC

СинтаксисADC приемник,источник
Машинный
код
14 ib — ADC AL,imm8
15 iw — ADC AX,imm16
15 id — ADC EAX,imm32
80 /2 ib — ADC r/m8,imm8
81 /2 iw — ADC r/m16,imm16
81 /2 id — ADC r/m32,imm32
83 /2 ib — ADC r/m16,imm8
83 /2 ib — ADC r/m32,imm8
10 /r — ADC r/m8,r8
11 /r — ADC r/m16,r16
11 /r — ADC r/m32,r32
12 /r — ADC r8,r/m8
13 /r — ADC r16,r/m16
13 /r — ADC r32,r/m32
ОписаниеСложение с учётом переноса.
ДействиеСложение двух целочисленных двоичных операндов с учётом флага переноса CF.
приёмник = приёмник + источник + CF
ФлагиOF=r SF=r ZF=r AF=r PF=r CF=r

При сложении чисел которые в результате дадут больше 16 бит происходит перенос старшего бита, из-за чего флаг CF (carry flag) меняет значение. Команда ADC учитывает значение флага CF предыдущей операции сложения и при вызове складывает операнды и добавляет значение CF (единицу или ноль) к младшему разряду результата.

Пример использования команды adc:

Рубрики
Справочник по ассемблеру

ADD

СинтаксисADD приемник,источник
Машинный
код
04 ib — ADD AL,imm8
05 iw — ADD AX,imm16
05 id — ADD EAX,imm32
80 /0 ib — ADD r/m8,imm8
81 /0 iw — ADD r/m16,imm16
81 /0 id — ADD r/m32,imm32
83 /0 ib — ADD r/m16,imm8
83 /0 ib — ADD r/m32,imm8
00 /r — ADD r/m8,r8
01 /r — ADD r/m16,r16
01 /r — ADD r/m32,r32
02 /r — ADD r8,r/m8
03 /r — ADD r16,r/m16
03 /r — ADD r32,r/m32
ОписаниеСложение.
ДействиеСложение двух целочисленных двоичных операндов.
приёмник = приёмник + источник
ФлагиOF=r SF=r ZF=r AF=r PF=r CF=r

Команда add выполняет операцию сложения. Результат сложения 2-х аргументов помещается в первый аргумент (приемник). Если результат выходит за диапазон приемника, изменяются флаги CF и OF (переполнение), SF (результат со знаком минус), которые интерпретируются в зависимости от того, являются ли складываемые аргументы числами со знаком или без.

Пример использования команды add:

Рубрики
Учебный курс

Учебный курс. Урок 8. Числа со знаком и без

Со школьной скамьи нас учили, что у чисел бывают отрицательные значения. Дело выглядело просто, записываешь число на бумаге, рисуешь черточку слева и все – положительное число превратилось в отрицательное. Для арифметической операции нужно от положительного числа отнять модуль отрицательного числа. К сожалению, такой подход совершенно не приемлем для машинных вычислений, потому что процессор не разделяет […]