Задачи и нити играют дополняющие друг друга роли. Задача владеет ресурсами системы, включая адресное пространство. Нить выполняет код. Процесс в традиционной системе UNIX представляет собой задачу, содержащую единственную нить. Многонитевый процесс состоит из одной задачи и некоторого количества нитей.
Также может иметь смысл заглянуть на сайт r-training.ru, ведь именно там можно узнать много нового на тему http://r-training.ru/catalog/collars. Тема электроошейник для собак отзывы может показаться на первый взгляд незначительной и даже не тематичной. Но стоит посетить сайт r-training.ru, и тема электроошейник для собак отзывы начинает проявлять себя с неожиданной стороны и вызывает всё больший интерес. Дело в том, что тема электроошейник для собак отзывы очень подробно представлена на сайте r-training.ru. Трудно найти более детальное освещение темы электроошейник для собак отзывы чем это сделано на сайте r-training.ru. Спасибо сайту r-training.ru за такое доскональное преподнесение темы электроошейник для собак отзывы.
Система Mach предлагает набор системных вызовов для работы с задачами и нитями. Вызовы task_create, tast_terminate, task_suspend и task_resume используются для работы с задачами. Вызовы thread_create, thread_terminate, thread_ suspend и thread_resume выполняют операции над нитями. Название каждого вызова красноречиво самодокументирует выполняемые им действия. Вдобавок к перечисленным вызовам имеются вызовы thread_status и thread_mutate для чтения и изменения состояния регистров нити, а вызов task_threads возвращает список всех нитей задачи.
Библиотека C-threads
Система Mach содержит библиотеку C-threads, которая обеспечивает простой интерфейс для создания и управления нитями. Например, функция
cthread_t cthread_fork (void* (*func)(). void* arg);
создает новую нить, в которой будет запущена функция funcQ. Нить может вызвать
void* cthreadjoin (cthread_t Т):
для приостановки своей работы до тех пор, пока не закончит функционирование нить Т. В вызывающий код нити вернется значение функции верхнего уровня нити Т или код выхода, выработанный после выполнения нитью Т функции cthread_exit().
Библиотека C-threads поддерживает взаимные исключения и условные переменные с целью осуществления синхронизации. В библиотеке имеется
функция cthread yield(), которая запрашивает планировщик на разрешение
выполнения другой нити вместо себя. Такая функция необходима только в случаях применения сопрограмм, описанных ниже.
Существуют три различных реализации библиотеки C-threads. Разработчик приложения может использовать вариант, наиболее отвечающий перечисленным ниже требованиям к разрабатываемому продукту.
♦ Приложение основано на сопрограммах (coroutine-based), где прикладные нити мультиплексируются в однонитевую задачу (процесс UNIX). Такие нити являются не вытесняемыми, библиотека выполнит переключение в другую нить только в случае выполнения процедур синхронизации (когда текущая нить должна быть блокирована на взаимном исключении или семафоре). Помимо этого библиотека полагается на нити, вызывающие функцию cthread_yield(), что защитит другие нити от долгого «стояния» в очереди. Эта реализация библиотеки подходит для отладки, так как порядок переключения контекста нитей является повторяемым.
4- Приложение основано на нитях (thread-based), каждая нить C-thread использует отдельную нить, поддерживаемую ядром Mach. Такие нити являются вытесняемыми и могут выполняться на многопроцессорных системах параллельно. Эта реализация является стандартной и используется для разработки различных вариантов программ, базирующихся на нитях C-thread.
4- Приложение основано на задачах (task-based), где используется одна задача, поддерживаемая ядром Mach (процесс UNIX) на каждую нить C-thread. Для совместного использования памяти между нитями применяются элементы виртуальной памяти, обеспечиваемые ядром Mach. Такой вариант используется только в случаях, когда необходима специализированная семантика разделения памяти.
Операционная система Digital UNIX (ранее известная как DEC OSF/1) основана на ядре Mach 2.5. С точки зрения разработчика приложений эта система предоставляет полный программный интерфейс UNIX. Однако внутренняя реализация многих возможностей традиционного варианта UNIX в этой системе опирается на базовые элементы ОС Mach. Эта реализация организована на уровне совместимости системы Mach с ОС 4.3BSD, расширенного фондом Open Software Foundation до совместимости с SVR3 и SVR4. Это свойство существенно повлияло на устройство системы Digital UNIX.
Система предлагает изящный набор средств, расширяющих понятие процесса [19].
Многонитевые процессы поддерживаются как на уровне ядра, так и на уровне совместимых со стандартами POSIX нитевых библиотек. Процесс UNIX реализован как верхний уровень задач и нитей системы Mach.
Опубликовал katy
July 03 2015 15:56:43 ·
0 Комментариев ·
3241 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.