Банк рефератов содержит более 364 тысяч рефератов, курсовых и дипломных работ, шпаргалок и докладов по различным дисциплинам: истории, психологии, экономике, менеджменту, философии, праву, экологии. А также изложения, сочинения по литературе, отчеты по практике, топики по английскому.
Полнотекстовый поиск
Всего работ:
364150
Теги названий
Разделы
Авиация и космонавтика (304)
Административное право (123)
Арбитражный процесс (23)
Архитектура (113)
Астрология (4)
Астрономия (4814)
Банковское дело (5227)
Безопасность жизнедеятельности (2616)
Биографии (3423)
Биология (4214)
Биология и химия (1518)
Биржевое дело (68)
Ботаника и сельское хоз-во (2836)
Бухгалтерский учет и аудит (8269)
Валютные отношения (50)
Ветеринария (50)
Военная кафедра (762)
ГДЗ (2)
География (5275)
Геодезия (30)
Геология (1222)
Геополитика (43)
Государство и право (20403)
Гражданское право и процесс (465)
Делопроизводство (19)
Деньги и кредит (108)
ЕГЭ (173)
Естествознание (96)
Журналистика (899)
ЗНО (54)
Зоология (34)
Издательское дело и полиграфия (476)
Инвестиции (106)
Иностранный язык (62792)
Информатика (3562)
Информатика, программирование (6444)
Исторические личности (2165)
История (21320)
История техники (766)
Кибернетика (64)
Коммуникации и связь (3145)
Компьютерные науки (60)
Косметология (17)
Краеведение и этнография (588)
Краткое содержание произведений (1000)
Криминалистика (106)
Криминология (48)
Криптология (3)
Кулинария (1167)
Культура и искусство (8485)
Культурология (537)
Литература : зарубежная (2044)
Литература и русский язык (11657)
Логика (532)
Логистика (21)
Маркетинг (7985)
Математика (3721)
Медицина, здоровье (10549)
Медицинские науки (88)
Международное публичное право (58)
Международное частное право (36)
Международные отношения (2257)
Менеджмент (12491)
Металлургия (91)
Москвоведение (797)
Музыка (1338)
Муниципальное право (24)
Налоги, налогообложение (214)
Наука и техника (1141)
Начертательная геометрия (3)
Оккультизм и уфология (8)
Остальные рефераты (21697)
Педагогика (7850)
Политология (3801)
Право (682)
Право, юриспруденция (2881)
Предпринимательство (475)
Прикладные науки (1)
Промышленность, производство (7100)
Психология (8694)
психология, педагогика (4121)
Радиоэлектроника (443)
Реклама (952)
Религия и мифология (2967)
Риторика (23)
Сексология (748)
Социология (4876)
Статистика (95)
Страхование (107)
Строительные науки (7)
Строительство (2004)
Схемотехника (15)
Таможенная система (663)
Теория государства и права (240)
Теория организации (39)
Теплотехника (25)
Технология (624)
Товароведение (16)
Транспорт (2652)
Трудовое право (136)
Туризм (90)
Уголовное право и процесс (406)
Управление (95)
Управленческие науки (24)
Физика (3463)
Физкультура и спорт (4482)
Философия (7216)
Финансовые науки (4592)
Финансы (5386)
Фотография (3)
Химия (2244)
Хозяйственное право (23)
Цифровые устройства (29)
Экологическое право (35)
Экология (4517)
Экономика (20645)
Экономико-математическое моделирование (666)
Экономическая география (119)
Экономическая теория (2573)
Этика (889)
Юриспруденция (288)
Языковедение (148)
Языкознание, филология (1140)

Курсовая работа: Разработка программы при помощи языка низкого уровня ассемблер

Название: Разработка программы при помощи языка низкого уровня ассемблер
Раздел: Рефераты по информатике, программированию
Тип: курсовая работа Добавлен 07:12:55 08 декабря 2009 Похожие работы
Просмотров: 97 Комментариев: 3 Оценило: 0 человек Средний балл: 0 Оценка: неизвестно     Скачать

ВОЛЖСКИЙ УНИВЕРСИТЕТ ИМЕНИ В.Н. ТАТИЩЕВА

Кафедра «Информатика и системы управления»

Курсовая работа

по дисциплине: «Организация ЭВМ»

Вариант - 107

Содержание

Введение

1 Постановка задачи

2 Описание и схема алгоритма

3 Листинг программы

Заключение

Список литературы


Введение

Если коротко, то язык ассемблера — это символическое представление машинного языка.

Все процессы в машине на самом низком, аппаратном уровне приводятся в действие только командами (инструкциями) машинного языка. Отсюда понятно, что, несмотря на общее название, язык ассемблера для каждого типа компьютера свой. Это касается и внешнего вида программ, написанных на ассемблере, и идей, отражением которых этот язык является.

По-настоящему решить проблемы, связанные с аппаратурой (или даже, более того, зависящие от аппаратуры как, к примеру, повышение быстродействия программы), невозможно без знания ассемблера.

Программист или любой другой пользователь может использовать любые высокоуровневые средства, вплоть до программ построения виртуальных миров и, возможно, даже не подозревать, что на самом деле компьютер выполняет не команды языка, на котором написана его программа, а их трансформированное представление в форме скучной и унылой последовательности команд совсем другого языка — машинного. А теперь представим, что у такого пользователя возникла нестандартная проблема или просто что-то не заладилось. К примеру, его программа должна работать с некоторым необычным устройством или выполнять другие действия, требующие знания принципов работы аппаратуры компьютера. И вот здесь-то и начинается совсем другая история.... Каким бы умным ни был программист, каким бы хорошим ни был язык, на котором он написал свою чудную программу, без знания ассемблера ему не обойтись. И не случайно практически все компиляторы языков высокого уровня содержат средства связи своих модулей с модулями на ассемблере либо поддерживают выход на ассемблерный уровень программирования.

Из всего вышесказанного можно сделать вывод, что, так как язык ассемблера для компьютера “родной”, то и самая эффективная программа может быть написана только на нем (при условии, что ее пишет квалифицированный программист). Здесь есть одно маленькое “но”: это очень трудоемкий, требующий большого внимания и практического опыта процесс. Поэтому реально на ассемблере пишут в основном программы, которые должны обеспечить эффективную работу с аппаратной частью. Иногда на ассемблере пишутся критичные по времени выполнения или расходованию памяти участки программы. Впоследствии они оформляются в виде подпрограмм и совмещаются с кодом на языке высокого уровня.

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

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

1 Ввод матрицы 4х4

2 Вывод введенной матрицы

3 Создание одномерного массива (первый элемент – минимальный элемент из строки номер 0, второй – максимальный из столбца номер 1 матрицы, третий – минимальный из строки номер 2 матрицы и т.д.)

4 Тестирование созданного массива (если положительные элементы чередуются то вывод на монитор этого массива, иначе вывод соответствующего сообщения).

2. Описание и схема алгоритма

Рисунок 1 – Алгоритм программы


Рисунок 1 продолжение – Алгоритм программы

Рисунок 1 продолжение – Алгоритм программы


Рисунок 1 продолжение – Алгоритм программы

Рисунок 1 продолжение – Алгоритм программы


Рисунок 1 продолжение – Алгоритм программы

3 Листинг программы

model smallinclude io.asm.dataadd_elem db 10, 13, 'Введите элементы матрицы : $'ishod_matrix db 10, 13, 'Исходная матрица : $'preobr_matrix db 10, 13, 'Преобразованная матрица : $'tab db 10, 13, ' $'pustie_str db 10, 13, 10, 13, 10, 13,'$'probel db ' $'m dw 4 ; размерность квадратной матрицыmatrix dw 4 dup (4 dup (?)) ; матрицаmas1 dw 4 dup(?)zn_chereduetsa db 10,13,'Знаки чередуются $'zn_nechereduetsa db 10,13,'Знаки не чередуются $'.stack 100h.codestart:mov ax, @datamov ds, axmov es, ax;--------------------------------------------------- очистка экранаmov ah, 06 ; 6-я функция ...mov al, 0 ; весь экран прокрутитьmov bh, 7 ; с цветами черный-белыйmov dx, 184Fh ; границы экрана: нижний правый...mov cx, 0 ; ... и верхний левый углыint 10h ; ... 10-го прерывания;--------------------------------- установка курсора в верхний левый уголMOV AH,2 ; 2 функция...MOV BH,0 ; координатыMOV DX,0 ; координатыINT 10H ; ... 10-го прерывания;--------------------------------- Ввод матрицы --------------------lea dx, add_elemmov ah, 09hint 21hlea dx, pustie_strmov ah, 09hint 21hlea dx, tab ; выводим смещение на сл. строку для красотыmov ah, 09hint 21hmov cx, 4 ; количество строкmov bx, 0 ; обнуляем bx - смещение по строкамm1: ;push cx ; сохраняем cx - количество строкmov cx, m ; сl <- количество столбцов(элементов в строке)mov si, 0 ; обнуляем si - смещение внутри строки(по столбцам)m2: ; с этой метки начинается ввод элемента в строкуinint matrix[bx][si]lea dx, probel ; выводим на экран пробел для красотыmov ah, 09hint 21hinc si ; увеличиваем смещение на 1inc siloop m2 ; если не равны, значит строка не закончилась т.е. заново вводимpop cx ; востанавливаем количество строкmov ax, m ; в al <- размер строкиadd bx, ax ; bx=bx+ax (переводим смещение на сл. строку)add bx, axlea dx, tab ; выводим смещение на сл. строку для красотыmov ah, 09hint 21newlineloop m1 ; если не равны значит строки не окончены т.е. заново;------------------------------------- очистка экранаmov ah, 06 ; 6-я функция ...mov al, 0 ; весь экран прокрутитьmov bh, 7 ; с цветами черный-белыйmov dx, 184Fh ; границы экрана: нижний правый...mov cx, 0 ; ... и верхний левый углыint 10h ; ... 10-го прерывания;-------------------------------- установка курсора в верхний левый уголMOV AH,2 ; 2 функция...MOV BH,0 ; координатыMOV DX,0 ; координатыINT 10H ; ... 10-го прерывания;-------------------- вывод матрицы на экранlea dx, ishod_matrix ; исходная матрица -mov ah, 09hint 21hlea dx, tab ; выводим на экран смещениеmov ah, 09hint 21hmov cx, m ; количество строкmov bx, 0 ; номер строки_m1: ;push cx ; сохраняемmov cx, m ; для того чтобы ввести количество столбцовmov si, 0 ; номер столбца_m2:outint matrix[bx][si] ; выводим элемент матрицыlea dx, probel ; далее выводим пробелmov ah, 09hint 21hinc si; переходим на сл. столбец (элемент строки)inc siloop _m2 ; если не конец строки, то зановоpop cx ; востанавливаем количество строкmov ax, m ;add bx, ax ; переход на сл. строку матрицыadd bx, axlea dx, tab ; выводим на экран смещениеmov ah, 09hint 21hloop _m1 ; если не последняя строка, заново;1- преобразование одномерной матрициmov cx, m ; количество сокmov bx, 0; номер строкиxor di,di_mm1: ;push cx ; сохраняемmov cx, m ; для того чтобы ввести количество столбцовmov si, 0 ; номер столбцаmov dx, matrix[bx][0] ; max=matrix[i][0]_mm2:cmp dx, matrix[bx][si] ; если matrix[i][j]<max то ререход на след элементjl bolshe; иначе max=matrix[i][j]mov dx, matrix[bx][si]mov mas1[di],dx; mas1=maxbolshe: inc si; переходим на сл. столбец (элемент строки)inc siloop _mm2; если не конец строки, то зановоpop cx ; востанавливаем количество строкmov ax, 8 ;add bx, ax ; переход на через строку матрицыadd bx, axmov ax, 4; переход через элемент матрици mas1add di, axloop _mm1 ; если не последняя строка, заново;2- преобразование одномерной матрициmov cx, 2 ; количество стОЛБЦОВmov di,2mov si,2_m_m1: ;push cx ; сохраняемmov cx, m ; для того чтобы ввести количество столбцовmov bx, 0 ; елемент i=0 j=2 делаю минимальнымmov dx, matrix[bx][si] ;_m_m2:cmp dx, matrix[bx][si] ;если [i][j]элемент матрицы > maxjg menshe;mov dx, matrix[bx][si] ;max= matrix[i][j]menshe: mov ax, 8 ;add bx, ax ; переход на сл. стобец матрицыloop _m_m2; если не конец строки, то зановоmov mas1[di],dx; mas1[i]=max i не четноеpop cx ; востанавливаем количество строкmov ax, 4 ;add si, ax ; переход на сл. столбец матрицыmov ax, 4add di, ax; переход на след елемет+1loop _m_m1 ; если не последняя строка, заново;вывод приеобразованной матрициlea dx, preobr_matrix ; преобразованная матрица -mov ah, 09hint 21hxor si,simov cx,4L: outint mas1[si] ; ФУНКЦИЯ ИЗ МОДУЛЯ IO ДЛЯ ЗНАКОВЫХ ЧИСЕЛlea dx, probel ; далее выводим пробелmov ah, 09hint 21hadd si, 2loop L; =================-=-=-=-=-=-=-=-= sravnenie elementov matricixor si,simov cx,3L_1: mov ax,mas1[si]imul mas1[si+1] ; умножение i го и i+1 элементаje znak_necher ; если болше 0 и = то два соседних элемента с одним знакомadd si, 2 ; АДРЕСС= АДРЕСС +2loop L_1;=--=-=-=-=-=-=-=-=-=-=vivod soobhsenii-=-=--=-=-=--=-=znak_cher:lea dx, pustie_strmov ah, 09hint 21hlea dx, zn_chereduetsa ;вывод сообщения о чередовании знаковmov ah, 09hint 21hjmp exitznak_necher:lea dx, pustie_strmov ah, 09hint 21hlea dx, zn_nechereduetsa ;вывод сообщения о нечеродовании знаковmov ah, 09hint 21hexit:mov ah, 7h ; задержкаint 21hmov ah, 4ch ; выход в DOSint 21hend start

Заключение

В данной курсовой работе был изучен теоретический по работе материал с прерываниями DOS, вводом и выводом чисел при помощи подключаемого модуля IO, работы с одномерными и двухмерными массивами, тестирование состояние флагов. Основные принципы и навыки работы с компилятором и отладчиком. Разработана схема алгоритма программы и реализована на языке низкого уровня ассемблер.

Список литературы

1. Каган Б. М. Электронные вычислительные машины и системы. Учебное пособие для вузов. – М.: Энергоатомиздат, 1991.

2. Ефремов В.Д., Мелехин В.Ф., Дурандин К.П. и др. Вычислительные машины и системы. Учебник для вузов – 2М.: Высшая школа, 1994.

3. Ларионов А.М., Майоров С.А., Новиков Г.И. Вычислительные комплексы, системы, сети.// Учебник для вузов. – Л.: Энергоатомиздат, 1987.

4. Микропроцессоры: в 3-х кн.: Учебник для вузов. /Под ред. Л.И.Преснухина - М.: Высшая школа, 1986.

5. МикроЭВМ: в 8 кн. /Под ред. Л.. Преснухина. – М.: Высшая школа, 1988.

6. Соловьев Г.Н. Арифметические устройства ЭВМ. – М.: Энергия, 1978.

7. Смирнов А.Д Архитектура ВС./ Учебное пособие для вузов. – М.: Наука.: Гл. ред. Физ.-мат.- лит., 1990.

8. Головкин Б.А. Параллельные вычислительные системы. – М.: Наука: Гл. ред. Физ.-мат. Лит., 1980.

9. Компьютеры на СБИС в 2-х кн.: пер. с японского/ Т.Мотоока, Х.Тонака и др./ - М.: Мир, 1980.

Оценить/Добавить комментарий
Имя
Оценка
Комментарии:
Где скачать еще рефератов? Здесь: letsdoit777.blogspot.com
Евгений06:39:44 19 марта 2016
Кто еще хочет зарабатывать от 9000 рублей в день "Чистых Денег"? Узнайте как: business1777.blogspot.com ! Cпециально для студентов!
16:19:20 29 ноября 2015
Кто еще хочет зарабатывать от 9000 рублей в день "Чистых Денег"? Узнайте как: business1777.blogspot.com ! Cпециально для студентов!
19:47:28 28 ноября 2015

Работы, похожие на Курсовая работа: Разработка программы при помощи языка низкого уровня ассемблер

Назад
Меню
Главная
Рефераты
Благодарности
Опрос
Станете ли вы заказывать работу за деньги, если не найдете ее в Интернете?

Да, в любом случае.
Да, но только в случае крайней необходимости.
Возможно, в зависимости от цены.
Нет, напишу его сам.
Нет, забью.



Результаты(151366)
Комментарии (1844)
Copyright © 2005-2016 BestReferat.ru bestreferat@mail.ru       реклама на сайте

Рейтинг@Mail.ru