
- •8.Буферизация данных при обмене информацией между процессами
- •9.Логическая организация механизма передачи информации
- •10.Алгоритмы планирования (Дисциплины диспетчеризации)
- •11.Аппаратные средства поддержки многозадачности.
- •12.Связь прикладного процесса с ядром ос.
- •13.Процесс – интерпретатор команд.
- •14.Реализация процедуры диспетчера процессов.
- •15.Реализация вытесняющей многозадачности.
- •16.Реализация кооперативной многозадачности.
- •17.Реализация карусельной многозадачности.
- •18.Адресация операндов в машинных командах.
- •19.Машинная команда и ее формат.
- •20.Методы адресации памяти
- •21.Вызовы, возвраты и определение подпрограмм
- •22.Основные сведения об организации подпрограмм
- •23.Директивы определения данных.
- •24.Структура программы на ассемблере.
- •25.Процедура компиляции, компоновки и отладки программ.
- •26.Общие сведения о языке ассемблера
12.Связь прикладного процесса с ядром ос.
Прикладные процессы, как правило, порождаются в рамках
пользовательского сеанса. Они могут выполняться как в интерактив-
ном, так и в фоновом режимах.
13.Процесс – интерпретатор команд.
Командный интерпретатор в среде UNIX выполняет две основные функции:
представляет интерактивный интерфейс с пользователем, т.е. выдает приглашение, и обрабатывает вводимые пользователем команды;
обрабатывает и исполняет текстовые файлы, содержащие команды интерпретатора (командные файлы);
В последнем случае, операционная система позволяет рассматривать командные файлы как разновидность исполняемых файлов. Соответственно различают два режима работы интерпретатора: интерактивный и командный.
В среде UNIX (в отличие, скажем, от DOS) имеются несколько различных командных интерпретаторов. Перечислим наиболее популярные:
/bin/sh - Bourne shell. Исторически это первая командная оболочка, разработанная для первой версии ОС UNIX. В настоящее время эта оболочка является основной в версиях UNIX System V.
/bin/csh - С-shell. Оболочка, синтаксис командного языка которой приближен к языку C. Является основной оболочкой для Берклеевской разновидности ОС UNIX.
/bin/ksh - k-shell.
/bin/rsh - Restricted shell. Представляет собой sh с ограниченными возможностями (прежде всего для защиты ОС от несанкционированных действий пользователя).
Операционная система ConvexOS является разновидностью 4.3 BSD UNIX( )BSD - Berkeley Series Distribution и, следовательно, базовой командной оболочкой является csh.
14.Реализация процедуры диспетчера процессов.
15.Реализация вытесняющей многозадачности.
Многозада́чность (англ. multitasking) — свойство операционной системы или среды программирования обеспечивать возможность параллельной (или псевдопараллельной) обработки нескольких процессов.
Вытесняющая многозадачность- вид многозадачности, в котором операционная система сама передает управление от одной выполняемой программы другой в случае завершения операций ввода-вывода, возникновения событий в аппаратуре компьютера, истечения таймеров и квантов времени, или же поступлений тех или иных сигналов от одной программы к другой. В этом виде многозадачности процессор может быть переключен с исполнения одной программы на исполнение другой без всякого пожелания первой программы и буквально между любыми двумя инструкциями в ее коде. Распределение процессорного времени осуществляется планировщиком процессов. К тому же каждой задаче может быть назначен пользователем или самой операционной системой определенный приоритет, что обеспечивает гибкое управление распределением процессорного времени между задачами (например, можно снизить приоритет ресурсоёмкой программе, снизив тем самым скорость её работы, но повысив производительность фоновых процессов). Этот вид многозадачности обеспечивает более быстрый отклик на действия пользователя.
Преимущества: возможность полной реализации многозадачного ввода-вывода в ядре ОС, когда ожидание завершения ввода-вывода одной программой позволяет процессору тем временем исполнять другую программу. Сильное повышение надежности системы в целом, в сочетании с использованием защиты памяти — идеал в виде «ни одна программа пользовательского режима не может нарушить работу ОС в целом» становится достижимым хотя бы теоретически, вне вытесняющей многозадачности он не достижим даже в теории. Возможность полного использования многопроцессорных и многоядерных систем.
Недостатки: необходимость особой дисциплины при написании кода, особые требования к его реентрантности, к защите всех разделяемых и глобальных данных объектами типа критических секций и mutex’ов.