КАТЕГОРИИ: Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748) |
Mas db 1,2,3,4,5,6,7,8,9,10
Data Циклы Rep outsb Mov cx, 16 Lea di, string Mov dx, 378h Outsd Outsw Outsb Вывод элемента цепочки в порт Rep insb Mov dx, 5000h Pop es Push ds Insd Insw Insb Ввод элемента цепочки из порта в строку Mov cx, 15 Mov es,ax Mov ds,ax Code Data Stosd Stosw Stosb Перенос элемента из аккумулятора в строку End main Mov ax, 4c00h Mov ah, 9h Jmp m1 Jcxz m Mov cx,6 Lea si, string2 Lea di, string1 Cld repe cmps string1, string2; сравнение пока cx>0 и zf=1 dec si; в регистре si адрес не совпавшего элемента строки lods string2; ( можно lodsb) загрузка байта 8 в аккумулятор m: mov dx, offset mes; загрузить адрес в dx int 21h; вывод сообщения «Элементы совпали» m1: int 21h
stos <приемник> Эту операцию удобно использовать вместе с операциями поиска с тем, чтобы, найдя нужный элемент, извлечь его в регистр и записать на его место новое значение. Адрес приемника записывается в пару регистров ES:DI. После выполнения команды происходит изменение содержимого регистра DI, равное значению размеру элемента строки: увеличение, если DF=0 или уменьшение, если DF=1.
Пример Записать в строку 15 пробелов: string db 15 dup (?) mov ax,@data cld; адрес увеличивается mov al, “ “; в al загружается пробел lea di, string; в di загружается адрес строки rep stosb; пересылать 15 байт (пробелов) : . ins <приемник>, <порт> b,d,w – размеры пересылаемых элементов. Номер порта должен быть записан в регистр dx. Адрес приемника записать в es:di. Размер элемента цепочки должен быть согласован с элементом порта. В CX указать количество пересылаемых байт (слов, двойных слов). После ввода элемента команда ins производит коррекцию содержимого регистра di на величину, равную размера элемента.
lea di, pole; адрес строки mov cx, 10; в cx количество пересылаемых байт : Outs <порт>, <источник>
Для работы этой команды необходимо предусмотреть: - номер порта записать в регистр dx - адрес источника записать в пару регистров DS: SI/ESI - размерность элемента строки совпадает с элементом порта.
Пример Для многократного выполнения некоторого блока команд используется команда loop <метка> Команда контролирует состояние регистра – счетчика цикла CX. Если состояние счетчика cx <> 0, то управление передается на метку в начале цикла, если cx=0, то происходит выход из цикла. После каждого выполнения тела цикла состояние счетчика cx уменьшается на единицу.
Для преждевременного выхода из цикла применяются команды: loope ( или loopz)<метка> Если cx>0 и zf=1, то управление передается на метку. Если cx=0 или zf=0, то управление передается на следующую команду.
loopne ( или loopnz)<метка> Если cx>0 и zf=0, то управление передается на метку. Если cx=0 или zf=1, то управление передается на следующую команду Фрагмент программы поясняет обнуление некоторого массива данных: . Пример простейшего цикла.
Программа выполняет обнуление массива
Дата добавления: 2014-01-04; Просмотров: 389; Нарушение авторских прав?; Мы поможем в написании вашей работы! Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет |