- •Ос в общей структуре компьютера.
- •История операционных систем.
- •Классификация современных ос. Задачи современных ос.
- •6. Понятие процесса – ключевое понятие ос.
- •8. Трансляторы: компиляторы и интерпретаторы.
- •9. Иерархия зу (запоминающих устройств).
- •10. Управление оперативной памятью (оп). Менеджер памяти; swapping; виртуальная память.
- •11. Модели организации виртуальной памяти.
- •12. История ос unix.
- •13. Общая архитектура unix. Основные подсистемы ядра.
- •14. Пользовательская среда unix.
- •Командный интерпретатор shell.
- •16. Система каталогов в oс unix. Управление с помощью команд языка Bourn shell.
- •17. Управление файлами с помощью команд языка Bourn shell. Перенаправление ввода/вывода.
- •19. Обработка аргументов командной строки. Переменные окружения.
- •20. Пользователь и группа. Права доступа к файлу.
- •21. Системные вызовы и функции стандартных библиотек. Обработка ошибок.
- •22.Структура программы на языке с. Параметры главной функции (пример).
- •23. Файловая система ос unix: монтирование, индексные дескрипторы, жесткие и символические ссылки, файлы устройств.
- •24.Системные вызовы для работы с файлами
- •25. Понятие «процесс» в ос unix. Контекст процесса; свойства процесса; состояние процесса.
- •26.Создание процессов и упр-е ими.
- •27. Запуск внешней программы
- •29.Общая классификация средств взаимодействия процессов в ос unix.
- •30.Иерархия процессов в ос unix. Понятие сеанса. Фоновые процессы.
- •31.Каналы – средства взаимодействия процессов. Неименованные каналы. Организация конвейера (пример программы).
- •33.Сигналы как средство взаимодействия процессов в ос unix. Диспозиция сигналов.
- •34.Ограничения для процесса в ос unix (по ресурсам). Связь со свойствами процесса.
- •36.Отображение файлов в виртуальное адресное пространство. Разделяемая память.
- •37. Взаимодействие процессов через псевдотерминал.
- •38. Недостатки потокового взаимодействия процессов. Средства System vipc. Пространство имен. Общие принципы работы со средствами System vipc.
- •39. Организация очереди сообщений в ос unix. Структура сообщения. Отправка и принятие сообщений.
- •40.Семафоры, как средство взаимодействия процессов System vipc. Понятие атомарной операции. Массив семафоров.
- •41.Разделяемая память, как средство взаимодействия процессов System vipc.
- •42.Взаимодействие по сети. Понятие протокола. Семейства адресации и типы взаимодействия. Создание сокета в ос unix.
- •45. Потоковые сокеты. Клиент – серверная модель.
- •46. Проблема очередности действий и ее решение.
- •47. Процессы-демоны. Система журнализации.
- •48. Загрузка и жизненный цикл в ос unix.
- •49. Взаимоисключения. Понятие критической секции. Устаревшие подходы к организации взаимного исключения.
- •50.Поддержка взаимоисключения на уровне ос. Мьютексы и семафоры (Дейкстры). Команда ассемблера tsl.
- •51.Проблема тупиков. Граф ожидания
- •52. Нити исполнения (pthreads) в ос unix. Мьютексы pthreads.
- •53.Графический интерфейс в ос unix. Базовые принципы построения x_window.
- •54.Файловая подсистема. Общая структура. Методы выделения дискового пространства. Управление дисковым пространством.
- •55.Файловая подсистема. Структура файловой системы на диске. Реализация директорий. Поиск в директории (хеширование).
- •56.Подсистема ввода/вывода. Схема взаимодействия подсистем ос. Понятие драйвера. Типы драйверов.
52. Нити исполнения (pthreads) в ос unix. Мьютексы pthreads.
Thread поток или нить. В 95 был принят стандарт, описывающий функции управления pthreads, распространяются и на win и на unix. Thread не имеет собственного адресного пространства. Поток должен иметь главную функцию
Void *my_thread_main (void*arg) {…}
Потоку в качестве стартового параметра можно передать указание на произвольную область памяти; может при завершении сообщить другим потокам результат работы в виде безтипового указ. Каждый поток имеет свой уникальный идентификатор, который можно сохранить в переменной типа threads_t
Создание и запуск потока
Int pthread_create (thread_t “th,pthread_attr_t” attr, void *(*start_routine)(void*)(void*arg).
Аргумент attr- специфические параметры работы нового потока, в большинстве случаев ставят нулевой указатель. Start_routine указывает на главные функции потока, эта функция будет запущена во вновь созданном потоке, причем на ввод ей будет передан указатель, который при организации create указывается в качестве параметра arg.Функция возвращает 0, в случае успеха, либо код ошибки. Для данной функции таким кодом мб значение EAGAIN, значит что для создания потока нехватило системных ресурсов. Поток может завершиться 2мя способами (вернуть управление из своей главной функции; завершить принудительно, вызвав функцию void pthread_exit (void*retval)
В первом случае результат- значение, возвращенное из главной функции, тип void*
Во втором случае -значение аргумента retval
Поток может дождаться завершения другого потока pthread_join(pthreads_t th,void*result) аргумент th задает идентификатор thread, завершения которго ждем, через параметр result передается адрес в который следует записать результат работы потока (похоже на wait pid). Результат завершения потока должен храниться, если его не вызовет join то он будет занимать системные ресурсы подобно зомби. Этого можно избежать , если перевести поток в отсоединенный режим int pthread_detach (pthreads_t th); их невозможно дождаться с помощью функции join, а значит нельзя проанализировать результат работы. Для detach и join 0-успех, либо код ошибки. Поток может узнать собственный идентификактор pthreads_t pthread_self.
Перевод потока в отсоединенный режим pthread_detach(pthreads_self());
Поток может досрочно завершить другой поток int pthread_cancel(pthreads_t th);
Результатом работы ph будет специальное значение PTHREAD_CANCELED, cancel не уничтожает поток, а отменяет его, что не всегда приводит к немедленному завершению потока. Возможно что поток завершится только дойдя до 1 из функций pthread, входящей в число точки обмена. Кроме основных действий проводит проверку на наличие запроса на отмену потока.
Мьютексы pthreads
В качестве mutex используется переменная pthread_mutex_t начальное значение соответствует состоянию mutex открыт, для этого следует проинициализировать переменную , сист знач pthreads_mutex_t my_mutex=PTHREAD_MUTEX_INITIALIZER открыт, представляет собой инициализ, т.е попытка подставить в mutex это значение может привести к ошибке при компиляции. Осн операции над mutex осуществляются с помощью функции
Int pthread_mutex_unlock(pthread_mutex_t)
Int pthread_mutex_lock(-//-) блокирующее закрытие с ожиданием
Int pthread_mutex_trylock(-//-) неблокир закрытие. Все функции возвращают в случае успеха, или код ошибки-неудача. Если trylock применяют к закрытому mutex она возвращает код ошибки EAGAIN.
Mutex уничтожен
Int pthread_destroy(-//-), высвободить системные ресурсы. Команда destroy формальна, в момент уничтожения mutex дб открыт.
POSIX- семафоры.
Семафоры изначально рассчитаны на работу нескольких процессов.В Unix можно использовать posix семафоры в рамках 1го полновесного процесса для взаимодействия потоков. В качестве семафора используется переменная типа sem_t Инициалу сем:
Int sem_unit(sem_t*sem, int pshared,unsigned Int volue);
Sem задает адрес инициализир семафора; shared указывает будет ли семафор доступен для других процессов, дб равен 0; volue- стартовые значения
int sem_post(sem_t * sem);Установка семафора (+1).
Int sem_wait(sem_t * sem);Ожидает ненулевого значения семафора. При вызове функции значение семафора уменьшается на единицу.
int sem_trywait(sem_t * sem);Неблокирующие ожидания ненулевого значения семафора.
В случае если семафор на момент вызова trywait имеет значение 0, функция возвращает ошибку EAGAIN. Можно программно определить текущее значение семафора Int sem_getvalue (sem_t*sem,int*sval)
Уничтожитель Int sem_destroy (sem_t*sem) не должно быть ни одного потока, находящегося в состоянии ожидания на семафоре.