Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
kratkie_otvety_ekzamen_CP_2011-12.docx
Скачиваний:
19
Добавлен:
14.04.2019
Размер:
132.13 Кб
Скачать

Краткий конспект к экзамену

1. Персональный компьютер (ПК) оперирует с большим количеством самых разнооб­разных данных, имеющих определенный формат, определяемый размером ячейки (коли­чество бит), где данное хранится, и способом его представления. Форматы допустимых данных зависят от модели персонального компьютера и от набора команд для их обра­ботки. Этот набор принят по умолчанию, независи­мо от модели ПК. Набор форматов данных для моделей i286 от базового ничем НЕ от­личается, добавлены только несколько команд. Этот базовый набор образует так называ­емую платформу Winl6, обеспечивающую 16-разрядное программирование. Поняв базовый принцип организации данных, мы легко поймем и дальнейшие расширения фор­матов данных и команд для i386, i486, i586 и совместимых с ними моделей ПК, обеспе­чивающих работу в Win32.

Любая величина, видимая программе, имеет тип и должна быть соответствующим об­разом представлена и описана. Займемся для начала простыми типами данных: символы(characters ASCII), целые(char, int) и вещественные(float, double, long double) числа. Как правило, в задаче всегда известен диапазон вводимых данных (область определения). Диапазон результирующих данных известен далеко не всегда. Поэтому обычно считают, что такие данные должны иметь максимально допустимый диапазон значений. При этом нужно учитывать, что данные более длинные требуют и больше памяти.

Двоичная сиситема — ее основаниеи q=2. Число в этой системе счисления образоывано из множества цифр {0,1}. Базовая еденица компьютерных данных называется бит. Слово является удобным сокращенеием неуклюжего английского выражения binary digit, т.е. двоичная цифра. Таким образом, двоичное число — последовательность бит. Преобразование чисел:Для преобразования из двоичной системы в десятичную используют следующую таблицу степеней основания 2:

512

256

128

64

32

16

8

4

2

1

Начиная с цифры 1 все цифры умножаются на два. Точка, которая стоит после 1, называется двоичной точкой. Преобразование двоичных чисел в десятичные: Допустим, вам дано двоичное число 110001. Для перевода в десятичное просто запишите его справа налево как сумму по разрядам следующим образом: 1*20+0*21+0*22+0*23+1*24+1*25=49

Доп.код:При записи числа в дополнительном коде старший разряд является знаковым. Если его значение равно 0, то в остальных разрядах записано положительное двоичное число, совпадающее с прямым кодом. Если же знаковый разряд равен 1, то в остальных разрядах записано отрицательное двоичное число, преобразованное в дополнительный код. Для получения значения, которое противоположно по знаку, все разряды, включая знаковый, инвертируются, а затем к результату добавляется единица.

Двоичное 8-ми разрядное число со знаком в дополнительном коде может представлять любое целое в диапазоне от −128 до +127. Если старший разряд равен нулю, то наибольшее целое число, которое может быть записано в оставшихся 7 разрядах равно 27 − 1, что равно 127.

2.3.ADD — ADD приемник, источник

INC — INC приемник

SUB — SUB приемник, источник

DEC — DEC приемник

CMP — CMP приемник, источник

MUL — MUL источник

DIV — DIV источник

4. AND операнд_1,операнд_2

OR операнд_1,операнд_2

ХОR операнд_1,операнд_2

TEST операнд_1,операнд_2

NOT операнд

на степень 2

MOV ax, число

SHL ax, степень полож. двойки

(SHR ax, отриц. степень двойки)

5. Преобразование двоичных чисел в десятичные

Допустим, вам дано двоичное число 110001. Для перевода в десятичное просто запишите его справа налево как сумму по разрядам следующим образом: 1*20+0*21+0*22+0*23+1*24+1*25=49

Преобразование десятичных чисел в двоичные

Допустим, нам нужно перевести число 19 в двоичное. Вы можете воспользоваться следующей процедурой :

19/2=9 c ост.1 > 9/2=4 с ост.1 > 4/2=2 с ост.0 > 2/2=1 с ост.0

1/2=0 с ост. 1

Итак, мы делим каждое частное на 2 и записываем остаток в конец двоичной записи. Продолжаем деление до тех пор, пока в делимом не будет 0. В результате получаем число 19 в двоичной записи: 10011.

Иногда, зная положительное число, требуется получить противоположное ему отрицательное число. Для этого используется команда NEG, обеспечивающая преобразование знака двоичных чисел из положительного в отрицательное и наоборот. Общий вид:

NEG <операнд> .

    Пример. Пусть регистр AX содержит слово 0001H. После выполнения команды NEG AX содержимым регистра AX будет FFFFH. Таким образом, команда NEG инвертирует значения битов и прибавляет 1.

6. операции с двоичными числами со знаком.

ADD (Сложение). Определяет двоичную сумму двух указанных операндов. Результат помещается на место операнда-приемника, второй операнд остается без изменения. Общий вид:

ADD <1-й операнд>, <2-й операнд>

<1-й операнд> <-- <1-й операнд> + <2-й операнд>

    Пример. Пусть регистр DL содержит число 58H, однобайтовая ячейка памяти TEST_BYTE содержит 27H. После выполнения команды ADD TEST_BYTE,DL в ячейку памяти будет записано 7FH:

содержимое регистра DL: 0101 10002 = 58H ;

содержимое ячейки TEST_BYTE: 0010 01112 = 27H;

новое содержимое ячейки TEST_BYTE: 0111 11112 = 7FH.

    Флаги, затрагиваемые операцией: OF, ZF, AF, PF, CF.

    2. ADC (Сложение с переносом). Определяет двоичную сумму двух указанных операндов и содержимого флага переноса CF. Результат помещается на место операнда-приемника, второй операнд остается без изменений. Общий вид:

ADC <1-й операнд>, <2-й операнд>

<1-й операнд> <-- <1-й операнд> + <2-й операнд> + <CF> .

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

    Пример 1. Пусть регистр BX содержит число 4803H, регистр AX - число 2517H, а регистр флагов процессора содержит значение F047H (11110000010001112), то есть флаг переноса CF равен 1. После выполнения команды ADC AX,BX вместо 2517H в регистре AX будет записано 6D1BH:

содержимое BX: 0100 1000 0000 0011 = 4803H;

содержимое AX: 0010 0101 0001 0111 = 2517H;

флаг переноса CF: 1 ;

новое содержимое AX: 0110 1101 0001 1011 = 6D1BH.

    Пример 2. Проиллюстрируем использование этой команды при сложении так называемых "длинных" чисел, которые не помещаются в одно слово. Пусть требуется сложить два таких числа:

224810H

23E1ADH

Сначала сложим младшие слова этих чисел, используя команду ADD:

4810H

E1ADH

------

(1)29BDH

Единица в скобках - это значение флага CF. Одновременно это значение, которое должно быть перенесено в следующий разряд. Мы должны его учесть при сложении старших разрядов этих чисел. Поэтому нужно воспользоваться командой ADC:

22H

23H

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]