15285

Налагодження програми мовою Асемблер з використанням циклів та розгалужень

Лабораторная работа

Информатика, кибернетика и программирование

Налагодження програми мовою Асемблер з використанням циклів та розгалужень Тема: Технологія та прийоми програмування мовою Асемблер. Мета роботи: набути навичок з реалізації задач мовою Асемблер що містять цикли та розгалуження. Ко...

Украинкский

2013-06-11

102.5 KB

10 чел.

PAGE  6

Налагодження програми мовою Асемблер з використанням циклів та розгалужень

Тема: Технологія та прийоми програмування мовою Асемблер.

Мета роботи: набути навичок з реалізації задач мовою Асемблер, що містять цикли та розгалуження.

 

  1.  Короткі теоретичні відомості

  1.  Команди передачі управління

До цієї групи відносяться команди, які дозволяють контролювати процес виконання програми. Це команди переходів. Розрізняють команди безумовного переходу і команди переходу за умовою. Команди цієї групи дозволяють організовувати розгалуження в програмах.

Безумовний перехід. Базовою командою, що передає керування в іншу точку програми, є команда JMP. Команда має наступний синтаксис:

JMP label,

де label -  це мітка, яка позначається іменем і знаком “:” після нього.

Імя мітки – це набір знаків, проте, імя  не може починатися з цифри. Нижче приведені приклади  правильних імен міток

label1:
label2:
a:

Мітка може записуватися в окремій стрічці тексту програми або перед командою, наприклад,

x1: 
MOV AX, 1

або


x2: MOV AX, 2

Нижче наведений приклад використання команди JMP:

org    100h

mov    ax, 5          ; set ax to 5.

mov    bx, 2          ; set bx to 2.

jmp    calc           ; go to 'calc'.

back:  jmp stop       ; go to 'stop'.

calc:

 add    ax, bx         ; add bx to ax.

jmp    back           ; go 'back'.

stop:

ret                   ; return to operating system.

Як бачимо з наведеного прикладу, команда JMP забезпечує передачу керування як вперед так і назад. Проте, перехід (стрибок) може здійснюватися тільки в межах сегменту (65,535 байт).

 Короткий перехід за умовою. На відміну від команди JMP, що забезпечує безумовний перехід, є команди, що забезпечують перехід тільки при виконанні певної умови. Такі команди поділяються на три групи. До першої груп відносяться команди, що аналізують один прапорець регістру стану. До другої групи відносяться команди, що порівнюють числа як знакові, і до третьої групи відносяться команди, що порівнюють числа як беззнакові.  

 Треба відмітити, що є деякі команди, які мають різні назви, проте дизасемблюються в один і той самий машинний код, наприклад, команда JE дизасемблюється як JZ,  команда JC дизасемблюється як JB. Різні назви використовують для кращого розуміння тексту програми.

  1.  Цикли

Алгоритмічна структура " цикл", як відомо, забезпечує виконання деякої послідовності дій, яка називається тілом циклу.

Виділяється три типи циклів: цикл " ДЛЯ", цикл " ДОКИ", цикл " ДО". Один від одного різні типи циклів відрізняються в основному лише способом перевірки закінчення циклу. Вказані типи циклів ілюструє рис.1.

Рисунок 1 Типи циклів

Система команд мови Асемблер дозволяє організувати циклічне виконання деякого фрагменту програми за алгоритмами, що представлені на рис.1, приміром, використовуючи команди умовної передачі управління або команду безумовного переходу JMP.

ЦиклДОКИ: While X>0 do S

Мовою Асемблер:

A1: CMP CX, 0

 JLE A2

S; тіло циклу

JMP A1

A2: …

 ЦиклДО: Repeat S until X>0

Мовою Асемблер:

A: S; тіло циклу

 CMP CX, 0

JLE A

 

ЦиклДЛЯ: For I=1 to N do S

Мовою Асемблер:

 MOV CX, N

A: S; тіло циклу

 DEC CX

CMP CX, 0

 JNE A

Як і в мові Паскаль, в Асемблері існує спеціальна команда, яка дозволяє скорочувати лістинг циклічної програми. Це команда

LOOP <мітка>.

Ця команда виконує наступні функції:

  •  Автоматично зменшує значення лічильника;
  •  Виконує перевірку на вихід з циклу;
  •  Виконує перехід на початок тіла циклу.

Команда LOOP може бути використана лише у разі циклу з відомим числом повторень, тобто циклу "ДЛЯ". Кількість повторень циклу має бути присвоєна регістру СХ до початку циклу.

Цикл “ДЛЯ з використанням команди  LOOP буде програмуватися наступним чином:

 MOV CX, N

A: S; тіло циклу

LOOP A

Таким чином, команда LOOP замінила три команди:

  •  DEC CX
  •  CMP CX , 0
  •  JNE A2

  1.  Вкладені цикли

У деяких випадках важливо повторити підзадачу кілька разів усередині більш загальної задачі. Один зі способів написання такої програми - включити цикл у набір інструкцій, що повторюються всередині іншого циклу. Така структура, що складається з циклу в циклі, називається вкладеними циклами.

При необхідності організувати вкладені цикли у програмі, написаній мовою Асемблер, для збереження лічильника зовнішнього циклу на час виконання внутрішнього зручно скористатися стеком.

  1.  Постановка завдання

  1.  Використовуючи середовище емулятора МП і8086, створити і налагодити проект асемблерної програми відповідно до індивідуального завдання і результатів виконання практичної роботи №3 зі складання програми для розв’язання  задачі: знайти числа A, B, C для яких виконується умова – A*B*C=A+B+C. Знайдені числа розмістити в трьох масивах – відповідно для чисел А, чисел В і чисел С.
    1.  Використовуючи середовище емулятора скласти лістинг програми (табл..1)

Таблиця 1 Лістинг програми

Зміщення

Код (Hex)

Мнемокод команди

К-сть байт

Коментар

100

C7

MOV w.[00136H], 0000 

6

Код операції – запис числа 0 в комірку памяті [00136H]

101

06

102

36

Молодший байт адреси

103

01

Старший байт адреси

104

00

Молодший байт операнду

105

00

Старший байт операнду

106

01

MOV CX, 0004H

3

Запис числа 4h в CX

107

04

Молодший байт операнду

108

00

Старший байт операнду

  1.  Запустити виконання програми в середовищі емулятора. Записати отримані результати виконання програми.
    1.  У випадку некоректної роботи складеної програми,  використовуючи покроковий режим роботи емулятора, виявити і усунути допущені помилки при складанні програми.

  1.  Варіанти індивідуальних завдань
    1.  Варіанти індивідуальних завдань наведені у табл. 2.

Таблиця 2 Варіанти індивідуальних завдань

№ варіанту

Розташування чисел

Діапазон зміни чисел

A

B

C

A

B

C

1

BL

CL

mem

0…5

1…5

0…9

2

BL

CH

mem

1…9

0…5

0…9

3

BH

CL

mem

0…9

1…7

0…5

4

mem

BL

BH

0…5

1…5

0…9

5

mem

CL

CH

1…9

0…5

0…9

6

mem

BH

CH

0…9

1…7

0…5

7

AL

mem

BL

0…5

1…5

0…9

8

BH

mem

AH

1…9

0…5

0…9

9

CL

mem

AL

0…9

1…7

0…5

10

BX

CX

mem

0…5

1…5

0…9

11

mem

BX

CX

1…9

0…5

0…9

12

BX

mem

mem

0…9

1…7

0…5

13

mem

CX

mem

0…5

1…5

0…9

14

mem

mem

AX

1…9

0…5

0…9

15

mem

mem

mem

0…9

1…7

0…5

  1.  Зміст звіту

  1.  Назва теми.
    1.  Мета роботи.
    2.  Індивідуальне завдання.

  1.  Алгоритми реалізації завдання.
    1.  Текст програми реалізації завдання з коментарями.
    2.  Результати виконання програми.
    3.  Висновки.
    4.  Відповіді на контрольні запитання.

  1.  Контрольні запитання
    1.  Які типи циклів застосовуються у програмах, складених мовою Асемблер?  
    2.  Які групи команд Асемблера застосовуються для організації циклів?
    3.  Які групи команд Асемблера застосовуються для організації розгалужень?
    4.  Що таке вкладені цикли і як вони використовуються?

  1.  Джерела інформації
    1.  Ю.І. Якименко, Т.О. Терещенко, Є.І. Сокол та ін. Мікропроцесорна техніка: Підручник. – Київ. – ІВЦ «Видавництво «Політехніка». – 2004. – 439 с.
    2.  Юров В., Хорошенко С. Assembler: учебный курс – СПб: Питер Ком, 1999. – 672 с.


“ДОКИ

мова

Тіло циклу

ДО

Умова

Тіло циклу

Так

Так

Ні

Ні

ДЛЯ

Лічильник

Тіло циклу


 

А также другие работы, которые могут Вас заинтересовать

84089. Монархическая форма правления её признаки и виды 22.49 KB
  Форма правления представляет собой структуру высших органов государственной власти порядок их образование и распределение компетенции между ними. Форма государственного правления дает возможность уяснить: как создаются высшие органы государства и какого их строение; как строятся взаимоотношения между высшими и другими государственными органами; как строятся взаимоотношения между верховной государственной властью и населением страны; в какой мере организация высших органов rocва позволяет обеспечивать права и свободы гражданина. По...
84090. Республиканская форма правления признаки и виды 22.12 KB
  Установлена республиканская форма правления. Эта республиканская форма правления отличается от монархии которой присуще наследование статуса главы государства. Если рассматривать форму правления с чисто формальных позиций то можно сказать что она не оказывает определяющего влияния на характер государственного строя.
84091. Смешанные формы правления в современном мире 24.83 KB
  Так было во время и после буржуазных революций в Европе и Америке: молодая прогрессивная буржуазия возглавлявшая широкие слои населения добилась ограничения власти монарха ликвидации абсолютизма установления дуалистической или парламентарной монархии а иногда и республики например в США. В ходе этого исторического развития были и своеобразные зигзаги: республика при фашизме во главе с фюрером дуче каудильо мало чем по существу отличалась от монархии хотя юридически форма была иной а республики в социалистических странах странах...
84092. Форма правления: понятие и виды 16.75 KB
  Форма правления представляет собой структуру высших органов государственной власти порядок их образование и распределение компетенции между ними. Форма государственного правления дает возможность уяснить: как создаются высшие органы государства и какого их строение; как строятся взаимоотношения между высшими и другими государственными органами; как строятся взаимоотношения между верховной государственной властью и населением страны; в какой мере организация высших органов государства позволяет обеспечивать права и свободы...
84093. Унитарное государство признаки и виды 20.55 KB
  Унитарное государство характеризуется следующими признаками: унитарное устройство предполагает единые общие для всей страны высшие исполнительные представительные и судебные органы которые осуществляют верховное руководство соответствующими органами; на территории унитарного государства действует одна конституция единая система законодательства одно гражданство; составные части унитарного государства области департаменты округа провинции графства государственным суверенитетом не обладают; унитарное государство на территории...
84094. Федерация: понятие и признаки, виды 23.76 KB
  Существуют следующие формы государственного устройства: 1 Унитарное государство 2 Федеративное государство 3 Конфедеративное на данный момент не существует в природе 4 Региональное государство Федеративное государство представляет собой добровольное объединение ранее самостоятельных государственных образований в одно союзное государство государство состоящее из государств членов или государственных образований субъектов федерации. На данный момент в мире насчитывается 24ре федерации. Федерации бывают: а Договорные и...
84095. Форма государственного устройства: понятие и виды 21.73 KB
  Территория федерации состоит из территорий ее отдельных субъектов: штатов кантов земель республик и т. Субъекты федерации имеют право принятия собственной конституции имеют свои высшие исполнительные законодательные и судебные органы 4. В большинстве федерации существует союзное гражданство и гражданство федеральных единиц. При федеральном государственном устройстве в парламенте имеется палата представляющая интересы членов федерации.
84096. Демократический режим и его признакии 22.3 KB
  В демократическом государстве существует взаимная ответственность государства и личности.Предоставление широкой свободы личности предприятиям и организациям в сфере экономической деятельности которая при демократическом политическом режиме составляет основу материального благосостояния граждан.Реальная гарантированность прав и свобод личности и реальная возможность реализовать данные права и свободы.Наличие эффективной и квалифицированной судебной защиты прав и свобод личности от произвола и беззакония со стороны кого бы то ни было.
84097. Антидемократические государственно-правовые режимы 25.92 KB
  Основными чертами тоталитарного политического режима являются следующие: государство стремится к глобальному господству над всеми сферами общественной жизни к всеохватывающей власти; общество полностью отчуждено от политической власти но оно не осознает этого ибо в политическом сознании формируется представление о единстве слиянии власти и народа; господствует монопольный контроль над экономикой средствами массовой информации культурой религией и т. фактически устраняется плюрализм; происходит централизация государственной...