Языком ассемблера. Для того, чтобы
Скачать 188 Kb.
|
И нформатика, 10 класс К.Ю. Поляков, Е.А. Еремин Практические работыДля выполнения этих работ используется учебный компьютер «ЛамПанель», который можно загрузить со страницы http://kpolyakov.spb.ru/prog/lamp.htm. |
Регистр | Десятичные значения | |
без учета знака | с учетом знака | |
R0 | | |
R1 | | |
R2 | | |
R3 | | |
Выполните программу
sub 1, R0
not R0
stop
при различных начальных значениях регистра R0 и запишите десятичные значения, полученные в R0 после выполнения программы:
До | После | |
без учета знака | с учетом знака | |
5 | | |
10 | | |
25 | | |
Какую операцию выполняет этот алгоритм? Найдите описание этого алгоритма в учебнике.
Ответ:
При тех же начальных значениях регистра R0 выполните программу
not R0
add 1, R0
stop
и заполните таблицу:
До | После | |
без учета знака | с учетом знака | |
5 | | |
10 | | |
25 | | |
Сделайте выводы, сравнивая результаты пп. 4 и 5.
Выводы:
Используя программу «ЛамПанель», вычислите арифметические выражения и запишите результаты в таблицу:
Выражение | Результат | |
без учета знака | с учетом знака | |
65530 + 9 | | |
32760 + 9 | | |
8 - 10 | | |
Замечание: в программу нужно вводить числа в шестнадцатеричной системе счисления!
Подсказка: 65535=FFFF16, 32767=7FFF16
Объясните полученные результаты:
Арифметические операции с целыми числами
З накомство с программой «ЛамПанель»
Кроме регистров общего назначения, с которыми мы уже работали, в процессоре есть служебные регистры. В этой работе мы будем использовать один из них – регистр состояния PS. Используются только три младших бита этого регистра (см. рисунок), которые показывают, какой результат был получен в результате последней операции:
бит C (от англ. carry – перенос) установлен (равен 1), если произошел перенос; в остальных случаях сброшен (равен 0);
бит Z (от англ. zero– ноль) установлен, если результат последней операции – ноль; в остальных случаях сброшен;
бит N (от англ. negative– отрицательный) установлен, если результат последней операции отрицательный; в остальных случаях сброшен.
бит O (от англ. overflow– переполнение) установлен, если в результате последней операции произошло переполнение и результат неверен; в остальных случаях сброшен.
Эти биты могут учитываться при выполнении следующей команды. Например, для организации цикла использую команду перехода
JNZ метка
Если результат предыдущей операции НЕ равен нулю, то происходит переход на указанную метку. Вот пример программы, которая вычисляет сумму натуральных чисел от 1 до 5:
MOV 0, R0 ; начальное значение суммы
MOV 5, R1 ; количество шагов цикла
m: ; метка обозначает начало цикла
ADD R1, R0 ; R0:= R0 + R1
SUB 1, R1 ; уменьшить R1 – оставшееся число шагов
JNZ m ; переход, если получился не ноль
STOP
Здесь в каждой строчке после точки с запятой записан комментарий, объясняющий ее действие. Давайте проследим, как выполняется эта программа:
Команда | R0 | R1 | бит Z | переход |
MOV 0,R0 | 0 | | 1 | |
MOV 5,R1 | | 5 | 0 | |
ADD R1,R0 | 5 | | 0 | |
SUB 1,R1 | | 4 | 0 | |
JNZ m | | | 0 | да |
ADD R1,R0 | 9 | | 0 | |
SUB 1,R1 | | 3 | 0 | |
JNZ m | | | 0 | да |
ADD R1,R0 | 12 | | 0 | |
SUB 1,R1 | | 2 | 0 | |
JNZ m | | | 0 | да |
ADD R1,R0 | 14 | | 0 | |
SUB 1,R1 | | 1 | 0 | |
JNZ m | | | 0 | да |
ADD R1,R0 | 15 | | 0 | |
SUB 1,R1 | | 0 | 1 | |
JNZ m | | | 1 | нет |
STOP | | | | |
Цикл заканчивается, потому что бит Z равен 1 (результат последней операции вычитания – ноль) и перехода по команде JNZ не происходит.
Задание на практическую работу
Запустите тренажер «Лампанель». Вычислите приведенные выражения с помощью программы. Запишите в таблицу результаты, значение знакового бита и битов O, C, N и Z.
Замечание: в программу нужно вводить числа в шестнадцатеричной системе счисления!
Выражение | Результат | Знаковый бит | Биты состояния | ||||
без учета знака | с учетом знака | O | C | Z | N | ||
32760+32752 | | | | | | | |
-32760-32752 | | | | | | | |
256-256 | | | | | | | |
Объясните полученные результаты:
Определите, в каких случаях произошло переполнение. Выделите эти строки таблицы желтым фоном.
С помощью программы, приведенной в теоретической части, вычислите сумму натуральных чисел от 1 до 100.
Программа:
Замечание: в программу нужно вводить числа в шестнадцатеричной системе счисления!
Ответ:
Напишите программу, которая вычисляет значение факториала – произведения всех натуральных чисел от 1 до заданного числа. Например, факториал числа 5 равен .
Для выполнения умножения используйте команду MUL (см. справочную систему, клавиша F1).
Программа:
С помощью программы заполните таблицу:
N | N! | |
без учета знака | с учетом знака | |
5 | | |
6 | | |
7 | | |
8 | | |
9 | | |
Объясните результаты, полученные в последних двух строчках:
http://kpolyakov.spb.ru