- •Лекция №1
- •История операционных систем.
- •Управление памятью.
- •Однозадачные системы.
- •Лекция №2
- •Способы учета участков памяти.
- •2 Алгоритм (наиболее подходящий).
- •3 Алгоритм (наименее подходящий).
- •4 Алгоритм (алгоритм двоичного разбиения).
- •Лекция №4
- •Принципы
- •Лекция №5
- •Лекция №6 Управление процессами.
- •Алгоритмы планирования системы.
- •Лекция №7
- •Два подхода к планированию.
- •Синхронизация.
- •Лекция №8
- •Тупики.
- •Способы взаимодействия между процессами.
- •Лекция №9 Управление процессами в среде Window’s.
- •Лекция №10
- •Волокна
- •Лекция №11 Синхронизация процессов.
- •Ссобытия
- •Способы взаимодействия процессов.
- •Серверная сторона
- •Второй семестр Управление процессами в среде unix Лекция №1
- •Лекция №2
- •Сигналы.
- •Способ взаимодействия общая память.
- •Лекция №3
- •Семафоры.
- •Лекция №4 Файлы как средства сообщения.
- •Файловыe системы.
- •Примеры файловых систем
- •Лекция № 6
- •Система ext 2
- •Лекция № 7
- •Лекция № 8 Функции работы с файлами в unix.
- •Лекция № 9 Java — скрипт.
- •Лекция № 10
- •Лекция № 11
Сигналы.
Сообщения, которые содержат только свой номер.
typedef void (*sighaudler_t) (int); - прототип функции обработки сигнала.
sighaudler_t signal (int num,
sighaudler_t n) – получает нмоер сигнала и устанавливает обработчикна сигнал с нмоером num, функция возвращает предыдущий обработчик.
В виде второго параметра могут использоваться
SIG_DFL – обработчик по умолчанию,
SIG_ING – игнорировать , не обрабатывать сигнал.
В системах есть два сигнала:
1) SIGSTOP
2) SIGKILL
с которыми мы сделать ничего не можем.
В системах Linux функция signal перехватывает обработку сигнала на 1 раз. После этого восстанавливается обработчик по умолчанию.
В системах FreeBSD все наоборот: перехватывает до тех пор, пока не будет отменен.
int kill (pid_t pid,
int num)
Отправить сигнал другому процессу
аналогичен параметру pid в waitpid, кроме
pid = -1, если вы пользователь, то функция отправляется всем процессам пользователя, если root – то всем процессам.
возвращает значение 0 – все хорошо, -1 – ошибка.
int raise (int num) – отправить сигнал самому себе.
Способ взаимодействия общая память.
Общая память в UNIX может выделяться только из общей памяти.
int shmget (key_t key,
int size,
int flags)
Получить доступ или создать новую к общей область физическую память.
Результат int – дескриптор объекта общей памяти.
Key – число, уникальный идентификатор объекта в системе, ключ доступа, с дескриптором не совпадает.
Size – размер в байтах.
Flags – может отсутствовать, тогда подключен к существующему объекту, иначе:
INC_CREAT – подключается к существующему, если его нет, то создаем новый.
IPC_EXCL – сам по себе не используется, может использоваться только с INC_CREAT – требуем, что мы создаем новый объект, если он есть – ошибка.
Лекция №3
Младшие 9 бит флагов означают права на данный объект (0666)
key_t ftok (char *filename,
int id)
Берет файл с идентификатором и создает ключ. Гарантирует, что имя файла и id на одной машине даст уникальный ключ.
void *shmat (int id, //shmget
const void *addr, //null
int flags)
Возвращает указатель на область памяти.
int shmdt (void *ptr) – обратная shmat. Функция отменяет отображение.
int shmctl (int id,
int cmd,
struct shmid_ds *buf)
Управляет объектами области памяти, выполняющая обычные команды cmd.
IPC_STAT – возвращает статистику
IPC_RMID – уничтожить объект
struct shmid_ds
{
struct ipc_perm shm_perm; // права владельца
int shm_segsz; // размер сегмента общей памяти в байтах
time_t shm_atime;
time_t shm_dtime;
unsigned short shm_cpid; // идентификатор объекта
unsigned short shm_lpid; // идентификатор последнего оператора
…
}
Только в Linux и только администратор может дать еще две команды:
IPC_LOCK – запрет свопинга страниц.
IPC_UNLOCK – разрешить свопинг.