Перейти к основному содержанию
EDU-MMCS
Вы используете гостевой доступ (Вход)

CS221. Архитектура компьютера и операционные системы

  1. В начало
  2. Курсы
  3. Осенний семестр
  4. Фундаментальная информатика и ИТ
  5. CS221 CA&OS
  6. Материалы лабораторных работ
  7. Лабораторная №2. Массивы. Условные и безусловные п...

Лабораторная №2. Массивы. Условные и безусловные переходы [3 балла]

Требуемые условия завершения
Открыто с: среда, 10 сентября 2025, 08:00
Срок сдачи: пятница, 19 сентября 2025, 11:25

Задания

Задача [task-1.s][1 балл]. Напишите программу которая суммирует все элементы массива. Результат остаётся в регистре AX. Для косвенной адресации к элементам массива следует использовать один из регистров:SI, DI. 

Задача [task-2.s][1 балл]. Напишите программу, которая суммирует все нечётные числа массива. Для проверки чётности используйте деление на 2 с помощью SHR: проследите, какой флаг может взводится этой командой в случае нечётных или чётных чисел и найдите в таблице инструкцию J**, которая анализирует именно этот флаг. Картинка, где показано расположение флагов в окне t88, поможет вам понять, за какой частью окна отладчика нужно следить при выполнении SHR. Решение этой задачи удобно писать на основе решения task-2.s.

Задача [task-3.s][1 балл]. Напишите программу, которая отдельно суммирует все числа массива, больше K, где K — переменная, заданная в секции данных, и отдельно суммирует числа, меньшие K. Первый и второй результаты в конце программы должны находиться в AX и BX соответственно. 

Дополнительное задание [1 балл]

Выше отмечалось, что инструкции J** аналогичны LOOP. Легко заметить, что с помощью инструкций J** тоже можно организовывать циклы. На самом деле, промышленные компиляторы практически никогда не генерируют инструкцию LOOP для организации цикла, а всегда обходятся J**. Это связано с тем, что LOOP занимает один регистр (CX) и использует его строго определённым образом, что не слишком удобно для большинства задач. В таком случае этот регистр просто «потерян» для программиста (или компилятора). Замена LOOP на J** позволяет избежать этого и более эффективно использовать имеющиеся регистры.

Задача [task-4.s]. Напишите программу, которая вычисляет значение выражения 8 x4 – x % 3 для x = 2, 3, 4 и последовательно записывает в массив res (в секции неинициализированных данных). Указания. Не использовать LOOP. Выбрать регистр для хранения очередного значения x и делать переход J** к началу тела цикла пока значение этого регистра меньше или равно 4. Для умножения на 8 используйте битовый сдвиг влево SHL: для сдвига на 2 и более (до 15) величину сдвига следует передавать в регистре CL (нижняя половинка регистра CX), чтобы загрузить в CL двойку, следует использовать инструкцию MOVB (B от byte).



  • jmp.png jmp.png
    7 сентября 2018, 10:17
◄ Лабораторная №1. Введение. Арифметика. Циклы LOOP [2 балла]
Лабораторная №3. Интерфейс системных вызовов. Простейшие подпрограммы. ►
Пропустить Навигация
Навигация
  • В начало

    • Страницы сайта

      • Мои курсы

      • Теги

    • Мои курсы

    • Курсы

      • Осенний семестр

        • Прикладная математика и информатика

        • Фундаментальная информатика и ИТ

          • Probability Theory and Mathematical Statistics

          • Научные Вычислительные Пакеты

          • DataSc101

          • NLP (7 семестр)

          • Compiler Development

          • CMVSM

          • АЗПК

          • Frontend

          • ТеорЯП

          • Ruby Eng

          • EngCA&OS

          • CS221 CA&OS

            • Общая информация

            • Материалы лабораторных работ

              • СтраницаПодготовка №1. Установка ПО.

              • ЗаданиеЛабораторная №1. Введение. Арифметика. Циклы LOOP ...

              • СтраницаПодготовка №2. Массивы. Условные и безусловные пер...

              • ЗаданиеЛабораторная №2. Массивы. Условные и безусловные п...

              • ЗаданиеПодготовка №3. Интерфейс системных вызовов. Просте...

              • ЗаданиеЛабораторная №3. Интерфейс системных вызовов. Прос...

              • СтраницаПодготовка №4. Подпрограммы (продолжение)

              • ЗаданиеЛабораторная №4. Подпрограммы.

              • ЗаданиеПодготовка №5. Работа с файлами

              • ЗаданиеЛабораторная №5. Работа с файлами

              • СтраницаПодготовка №6. Микропрограммирование

              • ФайлIJVM Assembly Language Specification

              • ФайлСправочник ассемблерных инструкций Java-машины

              • ЗаданиеЛабораторная №6. Микропрограммирование

            • Дистрибутивы и справочная информация

            • Доборы

        • Математика, механика

        • Педагогическое образование

        • Магистратура

          • Разработка мобильных приложений и компьютерных игр

        • Аспирантура

        • Вечернее отделение

        • Другое

        • Информатика-Осень-ПМИ-2

        • Информатика-осень-ПМИ-1

        • ИММвс

        • ФИиТ eng 2025

      • Весенний семестр

        • Прикладная математика и информатика

        • Фундаментальная информатика и ИТ

        • Математика, механика

        • Педагогическое образование

        • Магистратура

          • Разработка мобильных приложений и компьютерных игр

        • Аспирантура

        • Вечернее отделение

        • Другое

      • Воскресная компьютерная школа

        • Пользователь компьютера плюс

        • Пользователь прикладных программ

        • Программирование I ступень

        • Программирование II ступень

        • Программирование III ступень

        • Архив

      • Воскресная математическая школа

        • Открытое тестирование РНОМЦ и мехмата ЮФУ - 2025

        • Олимпиадная математическая школа

        • Повышение квалификации

        • Доступная математика

        • Лаборатория математического онлайн-образования мех...

        • Осенняя универсиада

        • Научно-практическая конференция

        • ВМШ

          • ВМШ -2025

        • Летняя олимпиадная математическая школа РНОМЦ и ме...

      • Государственная итоговая аттестация

      • Дополнительное образование

      • Олимпиады

      • Видеолекции

      • Разное

      • Архив курсов

      • Заочная школа мехмата ЮФУ

Служба поддержки сайта
Вы используете гостевой доступ (Вход)
CS221 CA&OS
Сводка хранения данных
Скачать мобильное приложение Яндекс.Метрика